• 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>
  • 相关阅读:
    h5 拍照上传 代码
    java jdbc 链接本地mysql数据库 报错 Access denied for user 'root'@'localhost' (using password: YES)
    react.js 中对props 的理解
    react.js 如何 设置页面div 背景图片
    关于Vue.js 和 react.js 的异同
    如何用 npm ,搭建react 项目
    如何进行vue vux版本更新
    js 继承 函数
    absolute 和 z-index妙用
    关于 white-space: pre-wrap;的灵异现象
  • 原文地址:https://www.cnblogs.com/ericblog1992/p/13132017.html
Copyright © 2020-2023  润新知