var allTags = document.evaluate("//*[contains(@src,'"+imgSrc+"')]", document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null);
这是给错误代码的工作,它给:document.evaluate不会从内容脚本
Uncaught Error: TYPE_ERR: DOM XPath Exception 52
有人能告诉我是什么问题?
var allTags = document.evaluate("//*[contains(@src,'"+imgSrc+"')]", document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null);
这是给错误代码的工作,它给:document.evaluate不会从内容脚本
Uncaught Error: TYPE_ERR: DOM XPath Exception 52
有人能告诉我是什么问题?
我没有一个确切的答案,但我可以猜测并给出解决方法。
首先解决:将UNORDERED_NODE_SNAPSHOT_TYPE
更改为不创建快照的类型(除非您需要这种方式)并返回多个节点,如UNORDERED_NODE_ITERATOR_TYPE
(或ANY_TYPE
)。
我的猜测是:在读取spec之后,它说这个函数'TYPE_ERR:如果结果不能被转换为返回指定的类型,则返回'。它可能是这样的情况下,它不能分配资源来创建快照或类似的东西(解决方法假设)。
编辑:
真正的问题是最有可能不调用document.evaluate
是,在你的代码做allTags.iterateNext
这个调用需要allTags
是一个* _NODE_ITERATOR_TYPE而不是* _NODE_SNAPSHOT_TYPE,使用allTags.snapshotItem
不导致错误被抛出。我在jsfiddle上写了一个示例,它在2秒后更改边界,使用调用来评估您的问题并以正确的方式遍历元素。
'imgSrc'的值是什么? – Prusse
这是一条路。出于测试目的,我们假设它是'http:// localhost/logo.png'。我最终为此使用了jQuery,但我仍然希望得到这个答案,因为jQuery不是很轻量级的。 – Bogdacutu