日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JSONP跨域请求数据报错 “Unexpected token :”的解决办法

發(fā)布時(shí)間:2025/3/18 javascript 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JSONP跨域请求数据报错 “Unexpected token :”的解决办法 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?原文??http://www.cnphp6.com/archives/65409

Jquery使用ajax方法實(shí)現(xiàn)jsonp跨域請(qǐng)求數(shù)據(jù)的時(shí)候報(bào)錯(cuò) “Uncaught SyntaxError: Unexpected token :”,主要問題在于返回的數(shù)據(jù)格式不正確

本地虛擬兩個(gè)域名,分別為:www.test.com、www.abc.com

http://www.test.com/index.html頁面點(diǎn)擊按鈕,請(qǐng)求返回?www.abc.com域名目錄下的文件的數(shù)據(jù)?,其代碼為:

<!DOCTYPE html> <html> <head><meta charset="utf-8" /> <title>JSONP跨域請(qǐng)求</title> <script src="http://www.oschina.net/js/2012/jquery-1.7.1.min.js" type="text/javascript"></script> <script type="text/javascript"> $(function(){ $(".button").on("click",function(){ $.ajax({ type:"get", url:"http://www.abc.com/json.php", dataType:"jsonp", jsonp:"callback", jsonpCallback:"success_jsonpCallback", success:function(json){ $(".user").html("用戶信息:"+json.username+","+json.age+","+json.gender); }, error:function(){ alert("請(qǐng)求出錯(cuò)!"); } }); }); }); </script> </head> <body> <button class="button">點(diǎn)擊獲取數(shù)據(jù)</button> <div class="user"></div> </body> </html>

http://www.abc.com/json.php文件代碼為:

<?php $arr = array ('username'=>'jack','age'=>21,'gender'=>'male'); echo json_encode($arr); ?>

在Chrome瀏覽器調(diào)試會(huì)發(fā)現(xiàn)報(bào)錯(cuò)了,如圖:

json.php返回的數(shù)據(jù)確實(shí)是json類型的數(shù)據(jù)?{“username”:”jack”,”age”:21,”gender”:”male”} ,問題處在哪?

翻看了一下Jquery文檔發(fā)現(xiàn)jsonp:”callback”,?jsonpCallback:”success_jsonpCallback”,傳遞這兩個(gè)參數(shù)是有原因的,jsonp的返回?cái)?shù)據(jù)格式應(yīng)該是: “客戶端傳遞的回調(diào)方法名稱(json數(shù)據(jù))”,將php文件改為:

<?php $arr = array ('username'=>'jack','age'=>21,'gender'=>'male'); echo $_GET['callback']."(".json_encode($arr).")"; ?>

測(cè)試,正確返回結(jié)果,如下圖:

可以看到,php文件返回的結(jié)果是?success_jsonpCallback({“username”:”jack”,”age”:21,”gender”:”male”}) ,這才是正確的jsonp返回格式,而?success_jsonpCallback這是傳遞過去的參數(shù)?。

轉(zhuǎn)載于:https://www.cnblogs.com/zhangycun/p/7504211.html

總結(jié)

以上是生活随笔為你收集整理的JSONP跨域请求数据报错 “Unexpected token :”的解决办法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。