Amb*_*pel 5 javascript scope bookmarklet
我正在尝试编写一个书签,它将 JSONP 调用添加到这样的页面中:
javascript:(function(){
var myFunction = (window.function(data){alert('my function is firing with arg' + data)});
var j = 'http://localhost/jsonscript.js';
var s = document.createElement('script');
s.src = j;
document.getElementsByTagName('head')[0].appendChild(s);
})();
Run Code Online (Sandbox Code Playgroud)
附加到页面中的脚本 src 包含
myFunction('foo');
Run Code Online (Sandbox Code Playgroud)
但是当我单击书签时出现错误 - myFunction 未定义。我如何“导出”该功能超出我的书签范围,以便从附加的脚本标签调用时它可以工作?
编辑:我发现我可以使用原始 JavaScript 打包脚本元素的 innerHTML。这有效,但很丑陋。我还是想找出更好的方法。
在窗口对象上定义函数:
window.myFunction = ...
Run Code Online (Sandbox Code Playgroud)
对于 JSONP 请求,您通常需要某种类型的计数器来递增,即:
var counter = 1;
var myFuncName = "myFunction" + counter;
var j = 'http://localhost/jsonscript.js?callback=' + myFuncName;
window[myFuncName] = function (data) {...};
// remove function after timeout expires
setTimeout(function () { delete window[myFuncName] }, 5000);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1336 次 |
| 最近记录: |