2017-01-12 48 views
-1

運行此代碼時,我在檢查時收到語法錯誤。我想在「輸出」div中顯示結果,但似乎存在翻譯問題。我必須使用jsonp,因爲我正在訪問我無法控制的服務器。顯示來自ajax api的jsonp數據調用

<!DOCTYPE html> 
<html lang="en"> 
<head> 
<meta charset="utf-8"> 
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> 
<meta name="Content-Script-Type" content="text/javascript"> 
<meta name="Content-Style-Type" content="text/css"> 
<link rel="stylesheet" href="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css"> 
<script src="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"  rel="javascript"></script> 
<script src="http://code.jquery.com/jquery-1.11.3.min.js" rel="jquery"> </script> 
</head> 

<body style="margin: 0px; padding: 0px;"> 

<div id="fullscreen"> 
<div id="output"> 

</div> 

</div> 

</body> 


<script> 
$.ajax({ 
type: 'GET', 
url: "https://avacmd25.scala.com:44335/ContentManager/api/rest/players?limit=1&offset=0&sort=name", 
dataType: "jsonp", 
jsonpCallback: 'callback', 
//data: {format: "jsonp"}, 
//data: JSON.stringify, 
success: function(response) { 
    console.log(response); // server response 
    { 
    var id = data[0];  
    var vname = data[1];   

    $('#output').html("<b>id: </b>"+id+"<b> name: </b>"+vname); 
    } 
} 
}); 
</script> 

跨域:

var proxyJsonp="https://script.google.com/macros/s/AKfycbwmqG55tt2d2FcT_WQ3WjCSKmtyFpkOcdprSITn45-4UgVJnzp9/exec"; 
jQuery.ajaxOrig=jQuery.ajax;jQuery.ajax=function(a,b){function d(a){a=encodeURI(a).replace(/&/g,"%26");return proxyJsonp+"?url="+a+"&callback=?"}var c="object"===typeof a?a:b||{};c.url=c.url||("string"===typeof a?a:"");var c=jQuery.ajaxSetup({},c),e=function(a,c){var b=document.createElement("a");b.href=a;return c.crossOrigin&&"http"==a.substr(0,4).toLowerCase()&&"localhost"!=b.hostname&&"127.0.0.1"!=b.hostname&&b.hostname!=window.location.hostname}(c.url,c);c.proxy&&0<c.proxy.length&&(proxyJsonp=c.proxy,"object"===typeof a? 
a.crossDomain=!0:"object"===typeof b&&(b.crossDomain=!0));e&&("object"===typeof a?a.url&&(a.url=d(a.url),a.charset&&(a.url+="&charset="+a.charset),a.dataType="json"):"string"===typeof a&&"object"===typeof b&&(a=d(a),b.charset&&(a+="&charset="+b.charset),b.dataType="json"));return jQuery.ajaxOrig.apply(this,arguments)};jQuery.ajax.prototype=new jQuery.ajaxOrig;jQuery.ajax.prototype.constructor=jQuery.ajax; 
+0

服務器是否返回JSONP ??什麼是確切的錯誤? –

+1

也有你的代碼中的錯誤。 console.log後面的括號應該會引發錯誤。沒有或正在創建對象。他們應該被刪除。 –

+0

@ D.Walsh大括號是多餘的,但除非出現計數不匹配,否則不會拋出錯誤,但似乎並非如此。 *例如* http://codepen.io/anon/pen/ZLWdVr?editors=0011 –

回答

0

通過該鏈接的外觀上來看,服務器返回的JSON,而不是JSONP。如果API支持它,則應該使用CORS

實施例:

$.ajax({ 
    type: 'GET', 
    url: "https://avacmd25.scala.com:44335/ContentManager/api/rest/players?limit=1&offset=0&sort=name", 
    dataType: "json", 
    crossDomain: true, 
    success: function(response) { 
      console.log(response); // server response 
      var id = response[0];  
      var vname = response[1]; 
      $('#output').html("<b>id: </b>"+id+"<b> name: </b>"+vname); 
    } 
}); 
+0

謝謝,但在試圖返回json dataType時,我得到了交叉原點錯誤。 – KevMoe

+0

太糟糕了。由於API不支持JSONP和CORS,因此您需要一個服務器端代理來連接它。 – bbailes