关于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);
以前的网页,网页没有消失,但脚本没有执行。
为什么?
答案 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
),因为所有变量都是在匿名函数的范围内创建的。