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>
  • 相关阅读:
    GridControl主从表设置
    Asp.net Ajax框架教程
    实现类似百度下拉框自动匹配功能
    将一个DataTable分解成多个DataTable
    找不到可安装的ISAM ,asp.net读取数据丢失,解决的一列里有字符与数字的
    StringCollection FAQ [C#, BCL]
    从枚举的初始化说起 [C#]
    当多态遇上数组 ... [C++] (Rewritten)
    我并不是不闻不问![C#]
    当多态遇上数组 ... [C++, C++/CLI, C#]
  • 原文地址:https://www.cnblogs.com/ericblog1992/p/13132017.html
Copyright © 2011-2022 走看看