javascript - 跨域获取ajax请求抛出解析错误

标签 javascript jquery cross-domain

$.ajax({
                type: "GET",
                url: "http://api.zip-tax.com/request/v20",                    
                data: {
                    key: '1234567890',
                    postalcode: '90265',
                    format: 'json'
                },
                success: function (json) {
                    debugger;
                    // do stuff with json (in this case an array)
                    alert("Success");
                },
                error: function (a, b, c) {
                    debugger;
                    alert("Error");
                }
            });

当我运行上面的代码时,它会将我抛出错误 block 并显示

SyntaxError: invalid label
[Break On This Error]   

{"version":"v20","rCode":100,"results":[{"geoPostalCode":"902

虽然它也显示了 readyState=4, status=200, statusText="success"parsererror 如果我点击该网址,我可以看到正确的 json

URL: `http://api.zip-tax.com/request/v20?key=1234567890&postalcode=90265&format=json`
Result: `{"version":"v20","rCode":100,"results":[{"geoPostalCode":"90265","geoCity":"MALIBU","geoCounty":"LOS ANGELES","geoState":"CA","taxSales":0.090000003576279,"taxUse":0.090000003576279,"txbService":"N","txbFreight":"N","stateSalesTax":0.064999997615814,"stateUseTax":0.064999997615814,"citySalesTax":0,"cityUseTax":0,"cityTaxCode":"","countySalesTax":0.0099999997764826,"countyUseTax":0.0099999997764826,"countyTaxCode":"19","districtSalesTax":0.014999999664724,"districtUseTax":0.014999999664724},{"geoPostalCode":"90265","geoCity":"PT DUME","geoCounty":"LOS ANGELES","geoState":"CA","taxSales":0.090000003576279,"taxUse":0.090000003576279,"txbService":"N","txbFreight":"N","stateSalesTax":0.064999997615814,"stateUseTax":0.064999997615814,"citySalesTax":0,"cityUseTax":0,"cityTaxCode":"","countySalesTax":0.0099999997764826,"countyUseTax":0.0099999997764826,"countyTaxCode":"19","districtSalesTax":0.014999999664724,"districtUseTax":0.014999999664724},{"geoPostalCode":"90265","geoCity":"TWAIN HARTE","geoCounty":"VENTURA","geoState":"CA","taxSales":0.075000002980232,"taxUse":0.075000002980232,"txbService":"N","txbFreight":"N","stateSalesTax":0.064999997615814,"stateUseTax":0.064999997615814,"citySalesTax":0,"cityUseTax":0,"cityTaxCode":"","countySalesTax":0.0099999997764826,"countyUseTax":0.0099999997764826,"countyTaxCode":"56","districtSalesTax":0,"districtUseTax":0}]}`

请指教。我不想编写服务器端脚本。

最佳答案

这不是 JSONP 的工作原理。

使用正确的 JSONP,<script>元素放置在带有 src 的页面上设置为您请求的 URL。这是由 jQuery 内部处理的。

JSONP 的响应不是 JSON。它是 JavaScript,调用函数并将 JSON 作为参数传递。这就是允许跨域数据传输的方式,因为您只是请求 Javascript 代码。

发出请求时,您必须提供要通过 JSON 响应调用的函数的名称,通常如下所示:

http://www.website.com/request/jsonp?param=value&param2=value2&callback=callbackFunc

因此,响应的格式为:

callbackFunc({JSON stuff});

jQuery 在内部处理此回调内容,以便 success方法最终被调用。

该 API 似乎不支持 JSONP ( http://www.zip-tax.com/documentation ),因此您必须对自己的服务器进行 AJAX 调用,让该服务器发出您需要的请求(返回 JSON),然后返回AJAX 响应中的 JSON。

关于javascript - 跨域获取ajax请求抛出解析错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16208242/

相关文章:

javascript - Rails 4 - 带有 gmaps4rails gem 的 Google map

javascript - 如何在 DataTables 的 FixedColumns 插件中交互式调整固定列的大小

Javascript:跨源资源共享的 XMLHttpRequest 问题

javascript - Cursometer - 渲染用户的鼠标速度

javascript - 如何在JavaScript中的窗口和框架之间共享数据

javascript - Cordova跨域文件://iframe contentwindow communication

javascript - Canvas Html5 Drawing App,移动 Canvas 导致大问题

javascript - 在异步编程中停止 javascript 循环

javascript - 在不同的选择选项上显示选择选项

jquery - 单击删除父 div