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>

 

posted @ 2020-06-15 17:07  EricBlog  阅读(128)  评论(0编辑  收藏  举报