7

如何使用 favelet 或脚本注入器在随机网站的页面上获取单击元素的 innerHTML?例如,单击此页面的“提问”正上方将返回以: 开头的内容<div class="nav mainnavs " style=""> <ul style=""> <li style="">

我尝试从 slayeroffice.com 编辑一个 favelet,其最初目的是删除所选元素的子元素,但它似乎不起作用。

javascript:
var b = new Array();
var c= 1;
var d;
document.onkeydown = ck;
el = document.getElementsByTagName('*');
for (i = 0; i < el.length; i++)
    {
        if (el[i].tagName.search(/(HTML|BODY)/i) == -1) 
        {
            if (el[i].title) el[i].oldTitle = el[i].title;
            el[i].title = el[i].innerHTML;
            d=String(el[i].innerHTML);
            el[i].onclick = function(e)
            {
                t = this;
                if (window.event) e = window.event;
                if ((t == e.target) || (window.event)) alert(d);
                if (window.opera) e.stopPropagation();
                return false;
            };
            el[i].onmouseover = function() 
            {
                if (!c) return;
                c = 0;
                t = this;
                b[t] = t.style.backgroundColor;
                t.style.background = '#DADADA';
            };
            void(
            el[i].onmouseout = function()
            {
                t = this;
                t.style.backgroundColor = b[t];
                c = 1;
            });
        }

    }
function ck(e) 
{
    k = window.event ? window.event.keyCode : e.keyCode;
    if (k == 27) 
    {
        for (i = 0; i < el.length; i++) {
            if (el[i].tagName.search(/(HTML|BODY)/i) == -1) 
            {
                el[i].oldTitle ? el[i].title = el[i].oldTitle : el[i].removeAttribute('title');
                el[i].onclick = null;
                el[i].onmouseover = null;
                el[i].onmouseout = null;
                el[i].style.backgroundColor = b[t];
            }
        }
    }

}

有什么解决办法吗?

4

2 回答 2

17

您可以将一个事件附加到文档 onclick 处理程序。无需遍历页面上的每个元素。点击会冒泡到它...

document.onclick = function(event) {
    var target = event.target || event.srcElement;

    alert ( target.innerHTML ); 
};

但是,我建议使用比使用“=”更好的方法来附加事件处理程序,因为它将覆盖任何先前定义的可能对页面操作至关重要的事件。

我之前使用过这个片段来更好地在没有 jQuery 的情况下附加事件......

var bindEvent = function(elem ,evt,cb) {
        //see if the addEventListener function exists on the element
        if ( elem.addEventListener ) {
            elem.addEventListener(evt,cb,false);
        //if addEventListener is not present, see if this is an IE browser
        } else if ( elem.attachEvent ) {
            //prefix the event type with "on"
            elem.attachEvent('on' + evt, function(){
                /* use call to simulate addEventListener
                 * This will make sure the callback gets the element for "this"
                 * and will ensure the function's first argument is the event object
                 */
                 cb.call(event.srcElement,event);
            });
        }
    }

你只要打电话...

bindEvent(document,'click', function(event) {
    var target = event.target || event.srcElement;

    alert ( target.innerHTML ); 
});
于 2013-05-17T14:13:18.113 回答
3

i您将遇到 for 循环中的范围的问题。

i将等于el.length点击发生的时间。

但是为什么要使用变量,当您可以读取它时

改变

if ((t == e.target) || (window.event)) alert(d);

if ((t == e.target) || (window.event)) {  
    alert(this.innerHTML);
}

你也不应该在 window.event 上检查 srcElement 吗?

于 2013-05-17T14:05:52.643 回答