手写jsonp

var util = {};
/**
 * [function 判断是否为函数]
 * @param  {[type]} source [description]
 * @return {[type]}        [description]
 */
util.isFunction = function (source) {
    return '[object Function]' === Object.prototype.toString.call(source);
};
/**
 * util里面的一个jsonp的方法
 * jsonp方法,利用script标签动态请求一个函数,函数的返回结果即为请求的响应结果
 * [function jsonp]
 * @param  {[type]} url      [description]
 * @param  {[type]} onsucess [description]
 * @param  {[type]} onerror  [description]
 * @param  {[type]} charset  [description]
 * @return {[type]}          [description]
 */
util.jsonp = function (url, onsuccess, onerror, charset) {
    // 获取一个随机五位字符串 作为返回的回调函数名
    var callbackName = util.getName('tt_player');
    // 把这个回调函数添加到全局window上面,如果onsuccess存在并且是一个回调函数的话
    window[callbackName] = function () {
        if (onsuccess && util.isFunction(onsuccess)) {
            onsuccess(arguments[0]);
        }
    };

    //创建一个script标签,请求一个url
    var script = util.createScript(url + '&callback=' + callbackName, charset);

    // script加载完毕(类似xhr也是会有一个状态码和回调函数的过程)
    // 这里的window[callbackName]会被成功调用,从而进入onsuccess函数,然后window[callbackName]会被清除掉
    script.onload = script.onreadystatechange = function () {
        if (!script.readyState || /loaded|complete/.test(script.readyState)) {
            script.onload = script.onreadystatechange = null;
            // 移除该script的 DOM 对象
            if (script.parentNode) {
                script.parentNode.removeChild(script);
            }
            // 删除函数或变量
            window[callbackName] = null;
        }
    };
    script.onerror = function () {
        if (onerror && util.isFunction(onerror)) {
            onerror();
        }
    };
    document.getElementsByTagName('head')[0].appendChild(script);// 添加标签到dom元素上
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值