javascript - jsonp跨域获取信息没有callback怎么获取信息
黄舟
黄舟 2017-04-11 13:28:27
0
2
583
<meta content="text/html; charset=utf-8" http-equiv="Content-Type" />  
<script type="text/javascript">  
    function jsonpCallback(data) {
    for(var i in data)alert(i);
}
</script>  
<script type="text/javascript" src="http://crossdomain.com/services.php?callback=jsonpCallback"></script>  

上面代码是有callback的,所以能获取到result和msg。
要是最下面那段代码没有callback(http://crossdomain.com/servic...,内容和有callback(http://crossdomain.com/servic...相比较,

jsonpCallback{"result":{"html":""},"msg":""}

{"result":{"html":""},"msg":""}

<meta content="text/html; charset=utf-8" http-equiv="Content-Type" />  
<script type="text/javascript">  
//这段该怎么填?
</script>  
<script type="text/javascript" src="http://crossdomain.com/services.php"></script>  

我的问题就是这段没有callback的我该怎么填?才能和有callback的弹出的是一样的值

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全員に返信(2)
洪涛

主要看你的后台是怎么写的。

要想有一模一样的值,services.php 就得做一些改动,不然是不可能实现的(数据内容是由php决定的,不是js决定的,js只是决定了如何展现数据而已)。

例如,要想返回一模一样的值,services.php 可以这样改:

js:
 function jsonpCallback(data) {
   alert(data);
 }

services.php:
$callback = isset($_GET['callback']) ? $_GET['callback'] : 'jsonpCallback';
$sendData = array(
  'result' => array(
                'html' => ''
              )
  'msg'    => ''
);
$sendData = $callback . ' ' . json_encode($sendData);
echo <<<EOT
<script>
 {$callback}({$sendData});
</script>
EOT;
いいねを押す +0
伊谢尔伦

jsonp可以理解为ajax获取字段js代码并且插入到dom和执行。 所以需要为被插入的js代码提供正确的执行环境。

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!