1

我读过的所有内容都说使用元素.onclick 属性,但这似乎不适用于我的情况。我正在尝试解析数字:629216818 并将其设置为变量:fbid。这是一个 Greasemonkey 脚本,因此无法直接编辑 HTML。我不是专业人士,所以我可能只是在做一些愚蠢的事情,但这是我的 HTML 和 Javascript:

<div id="petRightContainer">
<a title = "Pet trainer bonus: Your companion will level 5% faster." href="setup.php?type=companion&gtRandom=8167343321487308">
<div class="petRight" style="background-image:url(/fb/res/gui4/companion/cu_sith.jpg)"></div>
</a>
<div class="petRightLevel">
<a href="#" onClick="publishToWall('http://www.ghost-trappers.com/fb', 'Look at the cool augmentations my companion has received on Ghost Trappers.', 'Look at my new companion on Ghost Trappers!  I\'ve named it Jankie.  ', null, 'index.php?si=629216818&fromWall=1', 'white/companion_32.jpg', 'companion/wallpost_augmentation_12.jpg', 'companion/wallpost_augmentation_21.jpg', 'companion/wallpost_augmentation_11.jpg', null)">Dog</a>                        
</div>

等等

<script type="text/javascript">

    fbid = 0;
    fbidRegex = /\d{3,}(?=&fromWall=1)/;

    if ( document.getElementsByClassName("petRightLevel")[0]){

       element = document.getElementsByClassName("petRightLevel")[0].firstChild;
       codeStore = element.onclick;
       fbid = fbidRegex.exec(codeStore);
       document.write("it is working ");
    }

    document.write(fbid);

</script>
4

2 回答 2

0

我认为这可能对你有用。

<script type="text/javascript">
    fbid = 0;
    fbidRegex = /\d{3,}(?=&fromWall=1)/;
    if(document.getElementsByClassName("petRightLevel")[0]){
        element = document.getElementsByClassName("petRightLevel")[0].firstChild;
        // callback function to execute when the element onclick event occurs.
        codeStore = element.onclick = function(){
            fbid = fbidRegex.exec(codeStore);
            document.write("it is working ");
            document.write(fbid);
        }
    }
</script>
于 2012-05-26T03:28:19.233 回答
0

问题出在这一行:

element = document.getElementsByClassName("petRightLevel")[0].firstChild;

如果您使用的是 Firefox 和其他支持 HTML 的浏览器,则和document.getElementsByClassName之间有空格<div class="petRightLevel">

<a href="#" onClick= ...>

, firstChild 实际上是一个文本节点而不是链接。您需要做的就是删除两个元素之间的空格和/或换行符。

如果您使用的是 IE,问题仍然在 javascript 的同一行,因为 IE 直到版本 8 才支持 document.getElementsByClassName。

更新:以下 javascript 代码适用于我测试的所有浏览器,无需接触 HTML:

<script type="text/javascript">

    fbid = 0;
    fbidRegex = /\d{3,}(?=&fromWall=1)/;

    var divs = document.getElementsByTagName("div");
    var link = null;

    for (var i=0;i<divs.length;i++)
    {
       if(divs[i].getAttribute("class") ==="petRightLevel")
       {
          link = divs[i].getElementsByTagName("a")[0];
          break;
       }
    }
    if (link){
       codeStore = link.onclick;
       fbid = fbidRegex.exec(codeStore);
       document.write("it is working ");
    }

    document.write(fbid);

</script>

如果您只需要获取锚点,那将比这简单得多。

于 2012-05-26T05:37:45.003 回答