我想写一个(Scriptish)用户脚本,以便在各种网站上包含the Freebase suggestion search widget。我已经尝试了几种方法来实现这一点但到目前为止没有运气。
我的用户脚本看起来像(注意通配符包含):
// ==UserScript==
// @id meta@parsed.nl
// @name Meta
// @version 1.0
// @namespace
// @author
// @description
// @include *
// @run-at document-end
// @require https://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.js
// @require http://freebaselibs.com/static/suggest/1.3/suggest.min.js
// @noframes
// ==/UserScript==
$("head").append('<link type="text/css" rel="stylesheet" href="http://freebaselibs.com/static/suggest/1.3/suggest.min.css" />');
$("body").prepend('<input id="freebase-suggest" type="text"/>');
$("#freebase-suggest")
.suggest()
.bind("fb-select", function(e, data) {
alert("");
});
一切都很好,但是当我尝试使用搜索框时,它不起作用,并在错误控制台中显示以下错误:
错误:jQuery16101843227533633628_1325186688691未定义来源 文件: http://www.freebase.com/private/suggest?callback=jQuery16101843227533633628_1325186688691&prefix=ron+paul&type_strict=any&all_types=false 行:1
显然,脚本正在使用JSONP进行跨域请求,我的直觉是告诉我,回调jQuery16101843227533633628_1325186688691
正在与小部件所在的文档(Scriptish context与unsafeWindow)不同的上下文中定义。 / p>
我该怎么办?
答案 0 :(得分:0)
在DOM中添加jQuery和Freebase建议脚本并等待它们加载足以使其工作。但你必须参考unsafeWindow
。
var head = document.getElementsByTagName('head')[0];
// Only add jQuery if the site doesn't have it already (to prevent conflicts)
if (typeof unsafeWindow.jQuery === "undefined") {
var script = document.createElement('script');
script.type = 'text/javascript';
script.src = 'https://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js';
head.appendChild(script);
}
var script = document.createElement('script');
script.type = 'text/javascript';
script.src = 'http://freebaselibs.com/static/suggest/1.3/suggest.min.js';
head.appendChild(script);
window.setTimeout(function() {
$ = unsafeWindow.jQuery;
$("head").append('<link type="text/css" rel="stylesheet" href="http://freebaselibs.com/static/suggest/1.3/suggest.min.css" />');
$("body").prepend('<input id="freebase-suggest" type="text"/>');
$("#freebase-suggest")
.suggest()
.bind("fb-select", function(e, data) {
alert("");
});
}, 1000);
我不知道这种方法是否聪明,但确实有效。