Например, для PoC подойдет переопределение функции toString, а потом её неявный вызов:
toString=alert;window+1Или интереснее - переопределить ошибку.
onerror=eval;Uncaught=alert;throw'\x28location\x29';Тут мы определили
Uncaught как имя функции, в throw его содержимое (в том числе вызов), onerror можно переопределить в eval, а лучше в setTimeout, дабы всякие WAF'ы не ругались (пример). А тут еще больше примеров в репозитории XSS-Payloads (самый классный все равно innerHTML)