0

我正在尝试为 crawljax 编写一个运行一些 javascript 代码的插件,如下所示:

String result = browser.executeJavaScript(script).toString();

和脚本代码:

function getElementPosition(id) {
var element = document.getElementById(id);
return JSON.stringify(elementpos(findPosX(element), findPosY(element)));
}

function elementpos(x, y) {
elementpos = new Object();
elementpos.x = x;
elementpos.y = y;
return elementpos;
}


return getElementPosition("foo");

这成功返回,但结果始终为空,即使我使用 document.write 打印出相同的内容,我也会得到一个格式良好的 JSON 字符串

{"x":8, "y":24}

我是不是误会了什么?JSON字符串和java会发生一些奇怪的事情吗?我在javascript方面没有很多经验,所以我不能像那样返回吗?

我正在谷歌浏览器上测试这个,v. 25

注意:我认为它与 Crawljax 本身没有任何关系,因为有一个单独的插件(由其他人编写),它也有一个返回 JSON 字符串的脚本,但这似乎工作得很好......

4

2 回答 2

1

JavaScript 对new Object() 过敏;做一个捷径,试试下面的一个,可能会解决;

 return JSON.stringify({x:findPosX(element), y:findPosY(element)});

用new Object()创建的对象;语法在 javascript 中带来了许多奇怪的问题。

于 2013-03-08T23:24:29.097 回答
0

我认为这里的问题不在于 new Object(),但如果我在这一点上错了,请评论者随时填写。试试这个:

function elementpos(x, y) {
    var elementpos = new Object();
    elementpos.x = x;
    elementpos.y = y;
    return elementpos;
}

请注意,我已将“var”放在“elementpos = new Object();”前面。如果没有该变量定义,全局“elementpos”函数的第一行就是用“elementpos”对象替换自身。它第一次执行可能没问题,但第二次可能会失败并出现异常,因为它试图将 new Object() 结果视为要调用的函数。

我能够在 chrome 40 下执行上面的代码并将结果字符串化而没有任何问题。另请注意,调用局部变量“result”或函数名以外的其他内容将消除这里的一些潜在混淆。

于 2015-01-28T07:13:26.593 回答