0

我编写了代码来查询文档以查找匹配的字符串,并从获得的字符串中创建一个 URL。它通过标签元素查找匹配项,生成 URL 字符串,然后将链接附加到指定parentNode对象。这段代码在普通的 javascript 中运行良好,但是当我把它放在 Greasemonkey 中时它会中断。我不知道为什么。

当我将它粘贴在 chrome 控制台中时,这是一个完整的工作版本:

//loop  through elements by classname and find string matches
regexQueryEmail = "(AccountEmailAddress\\s)(.+?)(\\n)"
regexQueryContact = "(Contact with ID: )(.+?)(\\D)"

var Tags = document.getElementsByClassName('msg-body-div')
for (i = 0; i < Tags.length; i++) {
    matchEmail = Tags[i].innerText.match(regexQueryEmail)
    matchContact = Tags[i].innerText.match(regexQueryContact)
    if (matchEmail != null) {
        var emailString = matchEmail[2]
        var placeHolder = Tags[i]
    }
    if (matchContact != null) {
        var idString = matchContact[2]
    }
}

var urlFirst = "https://cscentral.foo.com/gp/stores/www.foo.com/gp/communications/manager/main/191- 4559276-8054240?ie=UTF8&customerEmailAddress="
var urlSecond = "%3E&initialCommId="
var cscURL = urlFirst + emailString + urlSecond + idString

var cscLink = document.createElement('a')
cscLink.innerText = 'Communication History'
cscLink.href = cscURL
placeHolder.parentNode.appendChild(cscLink)

当我将它粘贴在 Greasemonkey 中时,它在 Greasemonkey“编辑”屏幕上给了我这个错误:

/*
    Exception: Tags[i].innerText is undefined
    @Scratchpad:18
*/

它还告诉我“placeHolder”未定义,但我现在无法复制它。我有一种感觉,它与变量的作用域有关。我添加了“var Tags;” 和“var placeHolder;” 到脚本的顶部,它没有帮助。

4

1 回答 1

1

Firefox 使用该element.textContent属性。

https://developer.mozilla.org/en-US/docs/Web/API/Node.textContent?redirectlocale=en-US&redirectslug=DOM%2FNode.textContent

变量placeholderin 从未在您尝试使用它的范围内声明。而是在for循环中的某处声明。确保在同一范围内声明它。

例如

var Tags = document.getElementsByClassName('msg-body-div')

var placeholder; // declare in same scope

for (var i = 0; i < Tags.length; i++) {

    // lookup the tag once
    var tag = Tags[i];

    // get the text only once
    var text = tag.textContent;

    matchEmail = text.match(regexQueryEmail)
    matchContact = text.match(regexQueryContact)

    if (matchEmail != null) {
        var emailString = matchEmail[2]

        placeHolder = tag // deleted var statement
    }
    if (matchContact != null) {
        var idString = matchContact[2]
    }
}

...

// now you can use it.

if (placeHolder) {
    placeHolder.parentNode.appendChild(cscLink);
}
于 2013-05-24T19:09:18.257 回答