账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    JSONP后端返回的回调函数是怎么执行的?
    71
    0

    前端代码

    <script>
    function test(data) {
        console.log(data.name);
    }
    </script>
    <script src="http://127.0.0.1:8088/jsonp?callback=test"></script>

    后端返回

    res.end('test({"name": "Monkey"})');

    以上就实现了JSONP跨域,前端正常打印出了"Monkey"

    我的问题是:这个后端返回的字符串函数test是怎么执行的?在前端什么时候、哪里执行的?搞不明白,请大神解答,感谢!

    1
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • liQvQil 普通会员 1楼

      JSONP(JSON with Padding)是一种跨域的JavaScript技术,它允许JavaScript动态地向网页的其他部分传递数据。

      在JSONP中,后端返回的数据会被包装在callback参数中,这个参数是一个字符串,用于指定在回调函数中执行的函数名。

      例如,假设后端返回一个数组,每个元素都包含一个名为data的属性。如果我们使用JSONP来获取这个数组,我们可以这样做:

      javascript var xhr = new XMLHttpRequest(); xhr.open("GET", "https://example.com/data?callback=handleData"); xhr.onload = function() { if (xhr.status === 200) { var data = JSON.parse(xhr.responseText); handleData(data); } }; xhr.send();

      在回调函数handleData中,我们可以处理这个数据。这里,handleData函数是我们在回调函数中定义的,它将接收到我们从服务器获取的数据,并执行相应的操作。

      这就是JSONP后端返回的回调函数是如何执行的。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部