在两天的大部分时间里,我一直对这个 QuickBase jQuery/Ajax 问题感到困惑。考虑在 $(function()... 中运行的这个 jquery 代码:
<script type="text/javascript">
$(function() {
$.ajax({
type: "GET",
url: "https://www.quickbase.com/db/<mydbid>", // <- returns error
//url: "http://pfs.fedcap.com/testdata.xml", // <- returns xml
data: {
act:"API_DoQuery",
query:"{7.EX.235445}",
apptoken:"<myapptoken>"
},
dataType: "xml",
error: function(xhr,status) {
alert("error");
},
success: function(xml) {
alert("OK");
}
});
});
</script>
如前所述,指向 QuickBase 的 url 返回错误,但指向 xml 文件的 url 按预期返回 xml。但这里是关键:xml 文件 (testdata.xml) 是通过将我的浏览器直接指向指定的 url 创建的:https : //www.quickbase.com/db/<mydbid >?a=API_DoQuery&query={7.EX。 235445}&apptoken=<myapptoken> 并将结果保存到 testdata.xml。在我看来,jquery ajax 调用应该产生与 testdata.xml 文件相同的结果。但事实并非如此。
Firebug xml 窗格显示,对 QuickBase 站点执行的调用返回“XML Parsing Error: syntax error Location: moz-nullprincipal:{3e0d38f1-0e36-4adb-965e-d0e7d68ab0cb} Line Number 1, Column 1:Reload the page to获取来源:https ://www.quickbase.com/db ..."
我在看什么?有什么想法吗?