• jsonp 代码优化


    改进以后

      

    <script type="text/javascript">
            // 获取按钮
            var btn1 = document.getElementById('btn1');
            var btn2 = document.getElementById('btn2');
            // 为按钮添加点击事件
            btn1.onclick = function () {
                jsonp({
                    // 请求地址
                    url: 'http://localhost:3001/better',
                    data: {
                        name: 'lisi',
                        age: 30
                    },
                    success: function (data) {
                        console.log(123)
                        console.log(data)
                    }
                })
            }

            btn2.onclick = function () {
                jsonp({
                    // 请求地址
                    url: 'http://localhost:3001/better',
                    success: function (data) {
                        console.log(456789)
                        console.log(data)
                    }
                })
            }

            function jsonp (options) {
                // 动态创建script标签
                var script = document.createElement('script');
                // 拼接字符串的变量
                var params = '';

                for (var attr in options.data) {
                    params += '&' + attr + '=' + options.data[attr];
                }
                
                // myJsonp0124741
                var fnName = 'myJsonp' + Math.random().toString().replace('.', '');
                // 它已经不是一个全局函数了
                // 我们要想办法将它变成全局函数
                window[fnName] = options.success;
                // 为script标签添加src属性
                script.src = options.url + '?callback=' + fnName + params;
                // 将script标签追加到页面中
                document.body.appendChild(script);
                // 为script标签添加onload事件
                script.onload = function () {
                    document.body.removeChild(script);
                }
            }

            
        </script>
  • 相关阅读:
    Go:错误处理
    Go:闭包
    Go:内置函数
    Go:函数、defer
    mongodb 在PHP中常见问题及解决方法
    PHP 下载apk文件
    阿里云短信服务 PHP
    tp 创建文件并写入数据
    微信小程序中的加载更多(即列表分页)
    百度地图api逆地址解析 PHP
  • 原文地址:https://www.cnblogs.com/ericblog1992/p/13132017.html
Copyright © 2020-2023  润新知