Node.js中使用JSONP进行交互

在Node.js中实现JSONP非常简单,通过下面的代码我们从服务器返回并运行一个JavaScript函数,这个JavaScript函数已经在调用方提前被定义好了,于是当它被返回的时候就自动执行了。
 
var express = require(’express’);
 
var router = express.Router();
 
router.get(’/getinfo’, function(req, res, next) {
 
  var _callback = req.query.callback;
 
  var _data = { email: ‘example@163.com’, name: ‘jaxu’ };
 
  if (_callback){
 
      res.type(’text/javascript’);
 
      res.send(_callback + ‘(’ + JSON.stringify(_data) + ‘)’);
 
  }
 
  else{
 
      res.json(_data);
 
  }
 
});
 
module.exports = router;
 
代码中必须规定从服务器返回数据的类型,代码res.type(’text/javascript’)被加在返回的数据之前用于告诉浏览器这是一段JavaScript代码。
 
前端页面通过JQuery调用:
 
复制代码
 
<!DOCTYPE html>
 
<html lang=”en”>
 
<head>
 
    <meta charset=”UTF-8″>
 
    <title>jsonp test</title>
 
    <script src=”/bower_components/jquery/dist/jquery.js”></script>
 
</head>
 
<body>
 
    <input type=”button” value=”click” id=”btn”>
 
    <script type=”text/javascript”>
 
        $(function(){
 
            $(’#btn’)。on(’click’, function(){
 
                $.get(’http://anothersite/api/getinfo’, function(d){
 
                    console.log(d);
 
                }, ‘jsonp’);
 
            });
 
        });
 
    </script>
 
</body>
 
</html>

如需转载,请注明文章出处和来源网址:http://www.divcss5.com/html/h64693.shtml

张贴在3