联系我们
简单又实用的WordPress网站制作教学
当前位置:网站首页 > 网页前端技术 > 正文

用原生JavaScript实现jQuery的$.getJSON的解决方法 - Web前端

作者:98wpeu发布时间:2026-06-12分类:网页前端技术浏览:5


导读:  今天在写一DemO,其中用到了JQuery的$.getjson方法,写完后发现整个DEMO中用到jQuery中的就这一个地方,但要引入一个jquery实在不划算,于是就自己实现...

  今天在写一DemO,其中用到了JQuery的$.getjson方法,写完后发现整个DEMO中用到jQuery中的就这一个地方,但要引入一个jquery实在不划算,于是就自己实现了一个简单版的,基本可以满足需求,现分享出来:
复制代码 代码如下:
var $ = {
    getJSON: function(url, params, callbackFuncName, callback){
        var paramsUrl ="",
            JSONP = this.getQuerystring(url)[callbackFuncName];
        for(var key in params){
            paramsUrl+="&"+key+"="+encodeURIComponent(params[key]);
        }
        url+=paramsUrl;
        window[JSonp] = function(data) {
            window[jsonp] = undefined;
            try {
                delete window[jsonp];
            } catch(e) {}

            if (head) {
                head.removeChild(script);
            }
            callback(data);
        };

        var head = document.getElementsByTagName('head')[0];
        var script = document.createElement('script');
        script.charset = "UTF-8";
        script.src = url;
        head.appendChild(script);
        return true;
    },
    getQueryString: function(url) {
        var result = {}, queryString = (url && url.indexof("?")!=-1 && url.split("?")[1]) || location.search.substring(1),
            re = /([^&=]+)=([^&]*)/g, m;
        while (m = re.exec(queryString)) {
            result[decodeURIComponent(m[1])] = decodeURIComponent(m[2]);
        }
        return result;
    }
};

  调用DEMO如下:
复制代码 代码如下:
var url = "http://xxx.xxx.xxx?callback=jsonp123";
var params = {
    a:1,
    b:2
};
$.getJSON(url, params, "callback", function(data){
    //todo
});

标签:解决方法WebgetJSONjQueryJavaScript


网页前端技术排行
最近发表
网站分类
标签列表