Jsonp 解决跨域问题

Posted 雨V幕

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jsonp 解决跨域问题相关的知识,希望对你有一定的参考价值。

话不多说直接贴代码:

  $.ajax({
            async: false,
            url: http://****.****.com/Handler.ashx?vueId=iwNavpicS2,
            type: "GET",
            dataType: jsonp,
            jsonp: jsoncallback,
            data: null,
            timeout: 5000,
            beforeSend: function () {
                //jsonp 方式此方法不被触发.原因可能是dataType如果指定为jsonp的话,就已经不是ajax事件了
            },
            success: function (result) {//客户端jquery预先定义好的callback函数,成功获取跨域服务器上的json数据后,会动态执行这个callback函数
                var data = 1;
                if (name == "iwHeader1") {
                    result = JSON.stringify(result[0]);
                    result = result.replace("[[", "[").replace("]]", "]");
                    result = "{\"" + name + "\"" + ":" + result + "}";
                    data = JSON.parse(result);//将字符串转化为json对象

                } else {
                    result = JSON.stringify(result);//将josn 转化为字符串
                    result = result.replace("[[", "[").replace("]]", "]");
                    result = "{\"" + name + "\"" + ":" + result + "}";
                    data = JSON.parse(result);//将字符串转化为json对象
                    //console.log(JSON.parse(result).iwHeader1[0])
                }
                $("#val").val(data);
            },
            complete: function (XMLHttpRequest, textStatus) {
            },
            error: function (xhr) {
                //jsonp 方式此方法不被触发.原因可能是dataType如果指定为jsonp的话,就已经不是ajax事件了
                //请求出错处理
                alert("请求出错(请检查相关度网络状况.)");
            }
        });

注意,jquey是不支持post方式跨域的.

以上是关于Jsonp 解决跨域问题的主要内容,如果未能解决你的问题,请参考以下文章

怎么解决跨域问题

json跨域解决方案-jsonp

jsonp解决跨域问题

使用jsonp完美解决跨域问题

转Php+ajax+jsonp解决ajax跨域问题

说说JSON和JSONP,浅析JSONP解决AJAX跨域问题