无法使用书签运行外部JavaScript

时间:2010-02-08 15:00:38

标签: javascript bookmarklet

关于JS的新手。

我需要使用一个外部脚本来修改当前页面中的一些元素,将其作为书签进行访问。

如果我修改网页的html源代码,插入以下<脚本>行:

s=document.createElement('script');
s.type='text/javascript';
s.src='script.js';
document.getElementsByTagName('head')[0].appendChild(s);

它工作正常。但是,如果我创建一个具有相同行的javascript:bookmarklet,我将获得一个包含以下字符串的空白页:

[object HTMLScriptElement]

然而,如果我创建一个添加行的书签

void(null);

以前的网页,网页没有消失,但脚本没有执行。

为什么?

1 个答案:

答案 0 :(得分:7)

通常的做法是简单地使用自执行函数表达式,如下所示:

(function () {
  var s=document.createElement('script');
  s.type='text/javascript';
  s.src='script.js';
  document.getElementsByTagName('head')[0].appendChild(s);
}());

小书签:

javascript:(function(){var s=document.createElement('script');s.type='text/javascript';s.src='script.js';document.getElementsByTagName('head')[0].appendChild(s);}());

该函数将返回undefined(未提供返回值),阻止导航。

另请注意,这将避免创建可与页面上使用的其他变量重叠的全局变量(如s),因为所有变量都是在匿名函数的范围内创建的。