我正在处理一个项目,该项目需要从另一台服务器加载一些自定义 Dojo 小部件(即,我们自己编写的小部件)。尽管我在几天内尽了最大努力,但我似乎无法让 Dojo 加载小部件。
Dojo 从 Google CDN 加载,小部件从 www.example.com 加载,网站位于 www.foo.com。
我无法发布实际的项目文件(这是一个公司的项目),但我已经用较小的测试文件重现了该错误。
Test.html(在 www.foo.com 上):
<html>
<div id="content"></div>
<script>
var djConfig = {
isDebug: true,
modulePaths: {
'com.example': 'http://example.com/some/path/com.example'
}
}
</script>
<script src="https://ajax.googleapis.com/ajax/libs/dojo/1.4.3/dojo/dojo.xd.js.uncompressed.js"></script>
<script type="text/javascript">
dojo.require("dijit._Widget");
dojo.require("dijit._Templated");
dojo.addOnLoad(function() {
dojo.require("com.example.widget.Test", false);
dojo.addOnLoad(function() {
new com.example.widget.Test().placeAt(dojo.byId('content'));
});
});
</script>
</html>
Test.xd.js(位于 www.example.com/some/path/com.example/widget/Test.xd.js):
dojo.provide("com.example.widget.Test");
dojo.require("dijit._Widget");
dojo.require("dijit._Templated");
dojo.declare("com.example.widget.Test", [dijit._Widget, dijit._Templated], {
templateString: "<div dojoAttachPoint=\"div\">This is a test</div>",
postCreate: function() {
console.log("In postCreate");
console.log(this.div);
this.div.innerHTML += '!!!';
}
});
在 Firebug 中,我在延迟几秒钟后看到一个错误,提示无法加载跨域资源 com.example.widget.Test。但是,在“网络”选项卡中,我可以看到 Test.xd.js 已成功下载,并且可以设置断点并看到 dojo.declare 执行并完成而没有错误。
我很感激任何帮助。如果我可以提供任何其他信息,请告诉我。