为什么这个小书签 JS 代码在放入 onclick 处理程序时不起作用?
我有一个非常典型的书签代码,它在所有浏览器中都可以完美地工作。 但是,当我将此代码放入 HTML 元素的 onClick 处理程序中时,它在 IE(6、7 或 8)中不起作用。
这是代码:
javascript: (
function(){
function l(i,u){
var d=document;
var s;
try{
s=d.standardCreateElement('script');
}catch(e){}
if(typeof(s)!='object')
s=d.createElement('script');
try{
s.type='text/javascript';
s.src='http://{Domain}/bk/' + u;
s.id='s_' + i;
d.getElementsByTagName('head')[0].appendChild(s);
}catch(e){
}
}
AppD = '{Domain}';
l('b', 'bk.js');
}
)();
压缩为书签,看起来像:
javascript:function(){function l(i,u){var d=document;var s;try{s=d.standardCreateElement('script');}catch(e){} if(typeof(s)!='object') s=d.createElement('script'); try{s.type='text/javascript';s.src='http://{Domain}/bk/' + u;s.id='s_' + i;d.getElementsByTagName('head')[0].appendChild(s);}catch(e){}}AppD = '{Domain}';l('b', 'bk.js');})();
效果很好。 我已经取出了 javascript: 前缀,并将其放入元素的 onClick: 中,
<img onclick="function(){function l(i,u){var d=document;var s;try{s=d.standardCreateElement('script');}catch(e){} if(typeof(s)!='object') s=d.createElement('script'); try{s.type='text/javascript';s.src='http://{Domain}/bk/' + u;s.id='s_' + i;d.getElementsByTagName('head')[0].appendChild(s);}catch(e){}}AppD = '{Domain}';l('b', 'bk.js');})();" />
这也很好用,除了在 IE 中,bk.js 中的代码(被注入的脚本)抱怨变量 AppD 未定义。 ..
有什么想法为什么会发生这种情况吗?
可以放入 onClick 处理程序中的代码是否有任何限制?
谢谢! 丹尼尔
I have a pretty typical bookmarklet code that's working perfectly for me in all browsers.
However, when I take this code and put it in an HTML's element onClick handler, it doesn't work in IE (6, 7, or 8).
This is the code:
javascript: (
function(){
function l(i,u){
var d=document;
var s;
try{
s=d.standardCreateElement('script');
}catch(e){}
if(typeof(s)!='object')
s=d.createElement('script');
try{
s.type='text/javascript';
s.src='http://{Domain}/bk/' + u;
s.id='s_' + i;
d.getElementsByTagName('head')[0].appendChild(s);
}catch(e){
}
}
AppD = '{Domain}';
l('b', 'bk.js');
}
)();
Compressed down as a bookmarklet, that looks like:
javascript:function(){function l(i,u){var d=document;var s;try{s=d.standardCreateElement('script');}catch(e){} if(typeof(s)!='object') s=d.createElement('script'); try{s.type='text/javascript';s.src='http://{Domain}/bk/' + u;s.id='s_' + i;d.getElementsByTagName('head')[0].appendChild(s);}catch(e){}}AppD = '{Domain}';l('b', 'bk.js');})();
And that works perfectly.
I've taken out the javascript: prefix, and put it into an element's onClick:
<img onclick="function(){function l(i,u){var d=document;var s;try{s=d.standardCreateElement('script');}catch(e){} if(typeof(s)!='object') s=d.createElement('script'); try{s.type='text/javascript';s.src='http://{Domain}/bk/' + u;s.id='s_' + i;d.getElementsByTagName('head')[0].appendChild(s);}catch(e){}}AppD = '{Domain}';l('b', 'bk.js');})();" />
And that works well too, except than in IE, the code inside bk.js (the script that gets injected) complains that variable AppD is not defined...
Any ideas why this is happening?
Is there any limitation to the code one can put in an onClick handler?
Thanks!
Daniel
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
通过在变量声明前面添加 window.AppD 来解决。
Andrew Noyes 在另一个问题中提供的解决方案:
在内联 onclick 处理程序中可以执行的操作是否有任何限制?
Solved by adding window.AppD in front of the variable declaration.
Solution provided by Andrew Noyes in another question:
Are there any limitations to what can be done in an inline onclick handler?