zoukankan      html  css  js  c++  java
  • 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>
  • 相关阅读:
    别人走的路--2
    win7下80端口被(Pid=4)占用的解决方法
    实习第一天原来是配置环境
    api接口大全
    java计算两个日期之间相隔的天数
    【转】overload与override的区别
    Overload和Override的区别?
    浅析Java中的final关键字
    JAVA中的finalize()方法
    封装
  • 原文地址:https://www.cnblogs.com/ericblog1992/p/13132017.html
Copyright © 2011-2022 走看看