> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)

JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)

不言
풀어 주다: 2019-02-20 13:58:50
앞으로
2541명이 탐색했습니다.

이 기사는 JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예제)를 제공합니다. 이는 특정 참조 가치가 있으므로 도움이 될 수 있습니다.

Form submit

은 폼을 통해 포그라운드에서 백그라운드로 데이터를 제출할 수 있는 기능을 제공하며, 버튼에도 사용할 수 있습니다. 또는 기타 요소. 양식 제출을 유발하는 이벤트 submit事件,可以为按钮或其它元素同样可以触发表单提交的事件

  
로그인 후 복사
    账号:
    密码:
    重置:
       
<script> let btnObj=document.getElementById("btn"), formObj=document.forms[0];//forms表示获取页面中所有的表单,返回一个数组 btn.onclick=function(){ formObj.submit(); console.log("提交成功") } </script>

通过表单提交数据不需要依赖js引擎,浏览器本身就可以实现,但这样也会产生一个问题,用户提交数据信息的时候需要刷新整个页面,这就大大降低了用户体验

Ajax

什么是Ajax

Ajax的诞生解决了上述的问题,Ajax代表的是:Asynchronous Javascript And XML,也就是异步,javascript和XML,Ajax不是一门编程语言,而是一种用于创建更好更快交互性更强的web应用技术,可以通过少量的浏览器和服务器之间的数据交互实现页面的部分刷新,在使用了Ajax技术后,用户的请求数据是间接通过Ajax引擎来发出的,而不是直接通过浏览器来发出,服务器返回的数据也是传回到Ajax引擎

Ajax虽然在使用时的优点显而易见,但同时缺点也是存在的:

  1. 对搜索引擎不友好

  2. 用户无法使用回退获得之前的页面

我们可以对比一下传统的提交方式和使用Ajax技术的提交方式的不同:

JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)

Ajax引擎

Ajax的精华部分就是它的Ajax引擎,那么什么是Ajax引擎呢?就是XMLHttpRequest对象,除了已经入土的IE5,其它现代浏览器都支持该对象,同时它也是一个JavaScript对象,它负责发出请求和接收响应

在IE5和IE6中Ajax引擎是ActiveXRequest,所以我们可能需要做一下兼容性

<script>
  function createAjax(){
     var xhr;
     window.XMLHttpRequest?xhr=new XMLHttpRequest():xhr=new ActiveXObject("Msxml2.XMLHTTP");
     return xhr;
  }
</script>
로그인 후 복사

使用Ajax

创建Ajax引擎

    function createRequst() {
      return window.XMLHttpRequest ? new window.XMLHttpRequest() :
                    new window.ActiveXObject('Microsoft.XMLHTTP');
    }

    console.log(createRequst());//在IE7-中返回的是一个object对象
로그인 후 복사

我们在控制台中打印出XMLHttpRequest

    var xhr=createRequst();//封装的函数
    xhr.open("GET","data.php",true);
    //如果是使用GET方式提交数据那么需要在URl后添加?然后把键值对之间以&符号链接拼接在?后面
    //如果是使用POST获取数据,那么我们要将参数传递到send中,键值对与键值对之间使用&符号拼接
로그인 후 복사
양식을 통해 데이터를 제출하는 것은 js 엔진에 의존할 필요가 없지만, 이로 인해 사용자가 데이터 정보를 제출할 때 문제가 발생합니다. 전체 페이지를 새로 고쳐야 하므로 사용자 시간이 크게 줄어듭니다.

JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)

Ajax

Ajax란 무엇입니까

Ajax의 탄생은 위의 문제를 해결했습니다. Asynchronous Javascript And XML 즉, 비동기식, javascript 및 XML, Ajax는 동일하지 않습니다. 프로그래밍 언어이지만 더 좋고, 더 빠르고, 더 인터랙티브한 웹 애플리케이션을 만드는 데 사용되는 기술입니다. 적은 양의 데이터를 통해 페이지를 부분적으로 새로 고칠 수 있습니다. Ajax 기술을 사용한 후에는 사용자의 요청 데이터가 브라우저를 통해 직접 전송되지 않고 Ajax 엔진을 통해 간접적으로 전송됩니다. 서버에서 반환된 데이터도 Ajax 엔진으로 다시 전송됩니다

Ajax를 사용하면 장점이 분명하지만 단점도 있습니다.

검색 엔진에 친숙하지 않습니다.

사용자는 이전 페이지를 가져오기 위해 롤백을 사용할 수 없습니다.

기존 제출 방법과 기존 제출 방법의 차이점을 비교할 수 있습니다. Ajax 기술을 사용한 제출 방법:

2808208- 5ff030e931952132.png

Ajax 엔진

    Ajax의 본질은 Ajax 엔진인데, Ajax 엔진이란 무엇일까요? 묻혀 있던 IE5를 제외하고 다른 최신 브라우저에서는 XMLHttpRequest 개체를 지원하며 IE5 및 IE6에서 요청하고 응답을 받는 역할도 합니다. , Ajax 엔진은 ActiveXRequest이므로 호환성이 필요할 수 있습니다
  1. xhr.onreadystatechange=function(){
          if(xhr.readyState===4){
          //判断请求状态是否是已经完成
            if(xhr.status>=200&&xhr.status<p></p>Ajax를 사용하여 Ajax 엔진 만들기
    로그인 후 복사
  2. <meta>
    로그인 후 복사
  3. 의 메서드와 메서드를 인쇄합니다. 콘솔 속성의 XMLHttpRequest 개체
몇 가지 더 중요한 사항에 대해 이야기해 보겠습니다.

onloadstart는 요청이 시작될 때 트리거되는 이벤트입니다.

onloadend는 요청이 끝날 때 트리거됩니다.

    ontimeout은 요청 시간 초과
  1. onreadystatechange는 요청 상태가 변경될 때 트리거됩니다. 이벤트

  2. readyState 요청 상태
  3. status 서버에서 반환된 상태 코드

  4. timeout 요청 시간이 설정된 시간을 초과하면 요청이 수행됩니다. 자동으로 로그아웃됨
  5. withCredentials 인증서 필요 여부(예: 12306)

  6. responseText 비XML 형식으로 반환된 데이터
  7. 연결 설정
  8.     var xhr=createRequst();//封装的函数
        xhr.open("GET","data.php",true); 
        xhr.onreadystatechange=()=>{
          if(xhr.readyState===4){
            if(xhr.status>=200&&xhr.status
    로그인 후 복사
  9. 연결을 설정할 때 open 메소드를 호출해야 합니다. open 메소드에는 3개의 매개변수

    open(type, url, isAsync)가 있습니다. 이러한 매개변수는 각각

type, 요청 메소드, GET 또는 POST를 나타냅니다. 물론 DELETE와 같은 다른 메소드도 있지만 그렇지 않습니다. 일반적으로 사용되며 여기에 나열되지 않습니다. 🎜🎜🎜🎜url, 요청된 서버의 주소 🎜🎜🎜🎜isAsync, request 비동기 여부에 관계없이 기본값은 true입니다. 즉, 비동기 요청 🎜🎜🎜🎜GET 및 POST🎜🎜여기서 배경 데이터도 요청하는 GET과 POST의 차이점을 이해해야 합니다. 간단한 차이점만 나열하면: 🎜🎜🎜🎜GET 요청은 URL 주소 표시줄에 반영되며 POST의 보안이 취약합니다. 요청 본문에 제출되며 보안이 더 높습니다. GET 요청의 매개변수는 주소 표시줄에 저장되지만 POST는 그렇지 않습니다. 즉, 뒤로 키를 사용하면 GET 요청이 주소 표시줄에 저장됩니다. 주소 표시줄🎜🎜🎜🎜POST를 사용할 때 뒤로 키를 사용하면 제출이 반복되지만 GET은 불가능합니다. POST 방식은 이론적으로 불가능합니다. 크기 제한이 있으며, GET 방식에서는 브라우저가 주소 표시줄의 길이는 일반적으로 2K 문자 이내, 크기는 4K 이내로 제한됩니다. 초과 부분은 구문 분석되지 않습니다.🎜🎜🎜🎜매개 변수 유형의 경우 GET 메서드는 ASCLL 인코딩 형식만 지원합니다. POST에서(사용하기 전에 들어오는 데이터를 변환하는 것이 가장 좋습니다) 🎜🎜🎜🎜그러나 마스터의 기사를 읽은 후에는 위의 차이점이 더 이상 중요하지 않습니다. 둘🎜

我们都知道,无论是GET还是POST请求,都是建立在HTTP协议之上的,而HTTP协议又是建立在TCP协议之上的,也就是HTTP协议规定的数据在万维网中传输的的规定,那么说白了GET和POST只是两种不同的TCP链接,只是由于浏览器的规定设置导致了有一些差异,在本质上并没有什么区别,实际上真正的差别在于,GET和POST在传输数据的过程中,GET会产生一个TCP数据包,而POST会产生两个数据包

浏览器在发送GET请求时是将http header和data一起发出,服务响应200,而在发送POST请求时。浏览器会先发送http header,服务器响应100  continue,再发送data,服务器响应200,也就是说,GET方式提交数据是一次性的,而POST第一次先告诉服务器我要请求数据,第二次再将数据提交过去

所以这里由于POST是两次请求,耗时会增加,这也是雅虎优化建议中为什么提出,我们尽量将页面中使用POST的方式改为GET来提升响应速度,但是,在网络性能好的情况下,使用GET和POST的时间差别几乎没有,在网络较差的情况下,两次打包会大大提升数据的完整性,而且不是所有浏览器都是两次打包的,Firefox就是使用一次打包

至于安全性方面,GET和POST同样不安全,通过POST加密的数据会被抓包工具截取,如果有要求使用加密同样需要通过加密方式进行加密

监听状态信息

继续上面的栗子:

xhr.onreadystatechange=function(){
      if(xhr.readyState===4){
      //判断请求状态是否是已经完成
        if(xhr.status>=200&&xhr.status

这里有一些需要我们了解的

  1. readyState 请求的状态码

    0: 表示请求未初始化,也就是没有建立open请求

    1: 表示建立open()请求,正在发送请求

    2: 表示请求已经接收,open()方法已经完成,已经收到全部响应内容

    3: 表示请求处理中,正在解析响应内容

    4: 表示请求已经完成,响应也已经就绪,也就是说响应内容已经解析完成,可以在客户端进行调用了

  2. status 服务器返回的状态码,有几种常见的类型:

    以1开头代表请求已经接受

    以2开头代表请求已经成功

    1. 200,请求成功

以3开头代表网页重定向,常见的几个:

  1. 304,代表浏览器缓存可以继续使用,服务器没有返回数据,直接从浏览器中获取数据

以4开头代表请求错误 ,检查是不是url输入错误或者是后台人员接口给错了

  1. 404,无法找到指定的资源,也就是url地址错误

  2. 405,请求方法对请求资源不适用

  3. 403,请求不允许

以5开头代表服务器错误,需要后台人员配合进行调试

如何解决服务器返回304

浏览器有默认的缓存机制,在第一次向服务器请求数据的时候,在发现页面中存在文件请求时会发出请求,并将这些请求缓存在本地,在第二次向服务器发送请求的时候,在请求头中发送一个Last-Modified,它包含了上一次从服务器获得数据的日期。如果服务器判断从这个日期起服务器中数据没有进行修改,那么直接返回304的状态,不再重新发送数据,此时用户仅仅是获取了304状态码,不会再次请求数据,而是直接从本地读取缓存

避免服务器返回304最简单的方法就是直接在url地址中添加一个随机数的时间戳,例如:/Home/GetMusic?c_time=时间戳

在前端有个设置可以解决读取缓存的方法,设置meta标签的属性

<meta>
로그인 후 복사

或者设置Ajax默认禁止缓存

    var xhr=createRequst();//封装的函数
    xhr.open("GET","data.php",true); 
    xhr.onreadystatechange=()=>{
      if(xhr.readyState===4){
        if(xhr.status>=200&&xhr.status

如果使用jQuery进行开发,可以在在jQuery中设置Ajax的cache属性,该值默认为ture,设置为false即代表禁止浏览器缓存

发送请求头

在使用POST发送页面的时候需要注意的是,要发送请求头,格式如下:

xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
//设置请求头格式为仿照form表单提交
로그인 후 복사

在发送Ajax请求时默认发送的请求头格式为文本格式,如果用来提交表单数据会报错,所以需要我们认为的设置请求头格式,以上的代码的作用就是告诉服务器我们发送的是form表单格式的数据

发送请求

    xhr.send();
로그인 후 복사

这里我们注意一个问题,关于send()的位置问题,之前我们一直把send()放在监听事件状态onreadystatechange之前,这样写在默认的异步状态下是没有问题的,但如果是在同步的状态下看,是会报错的,这里涉及到了执行顺序的问题,我们是需要先准备好怎么样接收数据,然后才能对数据进行接收

JSON数据

json是一种键值对模式的字符串,其中的键和值都是用双引号进行包裹,由于json的轻量和便于使用,现在大部分公司使用的都是json格式的数据

var str={"name":"Tom","age",18}//如果值是数字的话可以不使用双引号包裹
로그인 후 복사

具体关于json的定义可以参考JSON

JSON的方法

在浏览器中为我们提供了两种json数据格式转化的方法

  1. JSON.parse(ison),该方法表示将接收到的json数据格式转化为对象格式,需要重点注意的是在使用该方法时,必须是键值对使用双引号包裹,所以外层的需要是单引号

  2. JSON.stringify(object),该方法表示将JavaScript中的对象转化为json格式的字符串

  3. 这里其实还有一个方法可以解析json格式的字符串,eval,这个方法比较特殊,W3C对它的介绍是,很强大的一个功能,但是运用的很少,这是因为eval方法本身会自动执行字符串中所包含的逻辑语句,所以如果我们使用该方法直接接收没有验证过的返回信息就会很容易遭到攻击,例如:

      var str={"name":alert("弹出")};
      var o=eval(str);
    로그인 후 복사

在执行上述代码时会自动弹出alert提示框,因为在使用eval时已经执行了字符串内部的逻辑代码,所以不推荐使用该方法

JQuery中的Ajax使用

在JQuery中对Ajax方法进行了封装,JQuery的Ajax封装是非常强大的,在其它框架中也大量借鉴了该方法,下面我们来看一下在JQuery中是如何使用Ajax的

比较简单方法:

      $(function(){
          $("#btn").on("click",function(){
             $.post("02.php",{name:"Tom",age:18},function(data){
                console.log(data)
             },'json')
          })
      })
      //相对应的还有GET和getJSON等其它方法,基本套路都一样
로그인 후 복사

下面的是我们经常用到的,同样也是在其他框架中被参考的方法$.ajax

      $.ajax({
        type:"get",//设置请求的方式
        url:"02.php",//设置请求的地址
        data:{name:"tom",age:18},//设置发送的参数
        dataType:"json",//请求的数据类型,自动转化为对象
        async:true,//设置是否异步,默认为true
        cache:false,//设置浏览器是否缓存该页面,默认为true
        timeout:300,//设置请求超时时间
        beforeSend:function(xhr){//请求开始前回调该函数
          console.log("请求开始前");
          //return false  如果在请求开始前直接return等于阻止了ajax请求
        },
        success:function(result,status){//请求成功时回调该函数,,result代表返回的数据,status为状态描述
          console.log("请求成功了");
        },
        error:function(xhr,status,error){//请求失败时回调该函数,xhr为 XMLHttpRequest对象,status为错误信息,error表示捕获的错误对象
          console.log("请求失败,"+xhr.status);
        }
      })
      //以上只是我们常用的一些方法和参数,JQuery中还封装了很多其它的方法和参数,包括上面提到的$.get和$.post等方法都是该方法的变种
로그인 후 복사

Ajax的封装

我们简单的模拟一下jQuery对Ajax的封装

function formatData(data) {//格式化数据的方法
    var ret = [];
    for (var key in data) {
        ret.push(encodeURIComponent(key) + "=" + encodeURIComponent(data[key]));
        //有时候传入的可能是汉字,所以需要利用encodeURIComponent转化成编码格式
        //encode方法废弃了,现在提供的是encodeURLConponent方法
    }

    ret.push(("=" + new Date().getTime()));
    //添加时间戳,防止获取缓存的数据(http状态码304)
    return ret.join("&");
}

function createRequst() {//创建Ajax引擎对象
    return XMLHttpRequest() ? new XMLHttpRequest() : new ActiveXObject("Msxml2.XMLHTTP")
}

function jsonp(option) { //jsonP方法
    //判断用户传入的参数
    if (!option || !option.url || !option.callback) {
        console.error("参数异常");
        return;
    }
    //如果用户参数传入正确,创建script标签,添加到head标签中
    var scriptElement = document.createElement("script"),
        headElement = document.getElementsByTagName("head")[0];
    headElement.appendChild(scriptElement);

    //注意jsonp创建的函数是全局函数,为了防止代码污染,起特定的名字
    var fnName = ("jsonp_" + Math.random()).replace(".", "");
    option.data[option.callback] = fnName;

    //给用户传入的向后台发送的data数据中添加一个option.callback属性,并赋值为我们自定义创建的函数名,让后台接收我们的函数名,后台才能返回给我们数据
    window[fnName] = function (data) {
        if (option.timeout) {//用户如果设置了超时时间,在接收到数据后将计时器清除
            window.clearTimeout(scriptElem.timer);
        }
        delete    window[fnName];//删除全局函数
        headElement.removeChild(scriptElem);//删除创建的script标签
        option.success && option.success(data);
    }
    if (option.timeout) {//如果用户设置了超时时间,设置计时器,在用户设置的超时时间到达后如果该函数执行,说明超时,那么执行其中的代码
        scriptElement.timeout = window.setTimeout(function () {
            delete global[fnName];
            headElem.removeChild(scriptElem);
            option.fail && option.fail({"message": "请求超时"});
        }, option.timeout)
    }
    scriptElem.src = option.url + '?' + formatData(option.data);//执行跨域请求,跨域的时候不需要其它参数,所以data中的数据就是callback和它的值
}

$.extend({
    AjaxSetting: {//设置用户默认输入的各项参数
        url: "",
        type: "GET",
        dataType: "json",
        async: true,
        success: null,//成功后执行的函数
        fail: null,//失败后执行的的函数
        contentType: "application/x-www-form-urlencoded;charset=UTF-8"//模拟表单提交的请求头

    },
    ajax: function (url, option) {//在JQuery中使用的两个参数,这里仿照JQuery写法

        var context, xhr;

        if (typeof url === "object") {//判断url类型,如果用户直接传入一个对象,说明没有单独传入URL地址,那么我们执行下面的代码
            option = url;
            url = null;
        } else {//如果用户单独传入了url地址,那么我们执行下面的代码
            option.url = url;
            url = undefined;
        }

        if (!option || !option.url || !option.success) {//判断用户是否输入option,option中的url和success是我们设置为默认必须的,所以在用户传入时就进行判断
            console.error("参数传入异常");
            return;
            //如果用户传入的参数异常,那么我们弹出异常,并且直接返回
        }
        // 通过JQuery中的extend方法获取默认设置
        $.extend($.AjaxSetting, context);
        // 通过JQuery中的extend方法获取用户设置,覆盖或新增默认的设置
        $.extend(option, context);

        if (context.dataType.toLowerCase() === "jsonp") {//判断用户是否要求跨域
            jsonp(context);//如果是的话执行jsonp的方法
        } else {//否则的话执行Ajax函数
            xhr = createRequst();//通过createReqyst方法执行函数
            xhr.onreadystatechange = function () {
                if (xhr.readyState == 4) {
                    if (xhr.status >= 200 && xhr.status <h1>Ajax轮询和长连接</h1><p>Ajax轮询和长连接都是为了实现页面的实时刷新,但是需要注意,如果在不是必要的情况下尽量不要使用这两种方法,大量的不间断的数据请求对前台和后台都是非常有压力的,如果要实现页面的实时刷新,建议使用<code>WebSocket</code></p><h2>Ajax轮询</h2><p>客户端定时向服务器发送Ajax请求,服务器在返回数据后断开连接,轮询能够实现页面的实时刷新,但是缺点也很明显,定时的发送数据大部分是没有意义的,而且占用额外的服务器资源</p><pre class="brush:php;toolbar:false">  
    function Ajax(){
        setInterval(function(){
             var xhr=new XMLHttpRequest();
                 xhr.open("open","url",true);
                 xhr.onreadystatechange=function(){
                     if(xhr.readyState===4){
                         if(xhr.status>=200&&xhr.status<p>代码实际上很简单,就是调用计时器,每过一段时间向后台发送一次请求</p><h2>long-polling</h2><p>所以为了能够使页面及时刷新,并且改善轮询存在的弊端,我们一般使用的是长轮询的方法,也就是ling-poling</p><pre class="brush:php;toolbar:false">    $(function(){
        (function longPolling(){
            $.ajax({
                url:"01.php",
                type:"get",
                datatype:"json",
                timeout:5000,
                error:function(xml,status,eror){
                     //可以选择报请求超时的错误,不过一般不这么做
                     longPolling();
                     
                },
                success:function(data,status,xhr){
                    console.log(data);
                    //如果有数据返回,那么将数据添加到页面
                    longPolling();
                }
            })
        })()
    })
로그인 후 복사

Ajax长轮询需要后台写相应的代码来配合完成,实际代码也就是无论成功或者失败都再次调用自身来向后台发起请求

模板引擎

什么是模板引擎,说白了就是在字符串中有几个变量待定,我们可以用来配合Ajax请求返回的数据来动态填充页面内容,例如:

//这里用到的是attTemplate模板引擎
<script>
//为了防止script对内容进行解析,将script的type属性变为非javascript即可,改为template主要是为了增加代码的可读性
        <tr>
            <td><%=name%> //<%= %>代表输出值
            <td><%=skill%>//在这里<%= %>中的skill代表的就是我们设定的待定的变量
            <td><%=wife%>
            <td>
                <% for(var i=0;i<friends.length;i++){ %>  // <%  %>里的内容代表的是输出的逻辑语句
                <a><%=friends[i]%>
                <% }%>
            
        
</script>
로그인 후 복사

我们可以在写一个完整的:

nbsp;html>


  <meta>
  Document
  <script></script>//导入模板引擎js文件
  <script>
    <% for(var i = 0;i < posts.length; i++) {%> 
      <%   var post = posts[i]; %>
      <% if(!post.expert){ %>
        <span>post is null
    <% } else { %> 
        <a href="#"><%= post.expert %> at <%= post.time %>
    <% } %>
    <% } %>
  </script>


<script>
  
    var data = {
    "posts": [{
        "expert": "content 1",
        "time": "yesterday"
    },{
        "expert": "content 2",
        "time": "today"
    },{
        "expert": "content 3",
        "time": "tomorrow"
    },{
        "expert": "",
        "time": "eee"
    }]
  };

    var str=template(&#39;template&#39;,data);//artTemplate模板引擎的使用就是调用template方法,传入模板的id和变量的值
    console.log(str)
</script>

로그인 후 복사

封装方法主要是使用了string的方法和正则进行匹配,下面写一下大概的封装

    function template(templateStr,data){//传入两个值,templateStr代表模板的字符串,data代表传入的变量对象

        var reg = /]+\S)\s*%>/,//定义正则匹配
            result;

        while(result=reg.exec(templateStr)){//根据正则的exec方法的属性如果没有符合的返回null来确定循坏停止的条件

            var matchString=result[0],//根据exec方法返回的是这部分的字符串

                matchWord=result[1];//根据exec方法返回的是中的字符,也就是我们传入的data中的键

            templateStr=templateStr.replace(matchString,data[matchWord]);
            //调用字符串的rplace方法,符合的目标进行替换
        }
        return templateStr;
    }
로그인 후 복사

跨域

什么是跨域

出于安全性的考量,现代所有的浏览器都遵循同源策略,同源策略不允许Ajax获取其它网站的数据,我们通过某种方式来获取其它网页的数据的方式就是跨域

同源策略

简单来说就是在两个网页域名,端口,协议任意不同的情况下,A网页无法获取B网页的数据,举一个例子来说明:

JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)

http://www.example.com/dir/page.html
http://www.example.com/dir2/other.html  //同源
http://example.com/dir/other.html    //不同源,域名不同
http://v2.www.example.com/dir/other.html    //不同源,域名不同
http://www.example.com:81/dir/other.html    //不同源,端口不同
로그인 후 복사

注意,同一域名下的不同服务器获取数据也是跨域,例如两台电脑的IP地址不同,A不能直接获取B电脑服务器的数据

如果是非同源那么会受到以下限制

  1. cookie, localStorage和indexDB无法读取

  2. DOM无法获取

  3. AJAX请求可以发送,但是无法获取响应

具体的内容可以参考:同源策略
 

跨域的方式

JSONP

什么是JSONP,很多人会把jsonp和Ajax搞混,或者认为jsonp是Ajax提供的跨域方法,但特别需要注意,这两者是相互独立的,这里引用一段知乎的回答

JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)

jsonp的本质可以认为是由于src属性不受同源策略的限制,可以获取其它域的数据,利用src能够跨域获取数据的特性来实现我们从其它的网站获取数据,前提是必须在该网站配合下

实际在之前的很多操作中我们已经使用到了src能够跨域的这个特性,例如我们在img中插入一张图片,可以直接把图片的地址复制到src中

 <img  alt="JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)" >
로그인 후 복사

所以需要注意,src这个属性实际上是等同于发送了一个GET形式的Ajax请求,包括href,所以我们在页面中尽量不要写空的hrefsrc属性,可以减小服务器的压力

下面我们来举一个jsonP跨域的例子:

<script>
</script>
<script>
   function sayhi(data) {
    //参数data就是我们要获取的跨域的数据,在拿到之后可以配合模板引擎在页面中放置
       console.log(data);
       //sayHi方法会自执行,因为在后台传送数据时会用括号将callback的值包裹起来
   }
  //后台在接收到`callBack`后,获取到`sayhi`的名称,返回`sayhi(&#39;("+data+")&#39;)`,所以我们接收的函数的参数就是我们要获取的数据
</script>
로그인 후 복사

在JQ中为我们封装了跨域的方法,有两种方式:

1.$.ajax()方法
<script>
  $(function(){
    $.ajax({                
      url:"http://api.map.baidu.com/telematics/v3/weather?location=北京                                            &output=json&ak=tq0Kt0NFYheTCj5mszast0drkIqqVTNn",                
      dataType:"jsonp",//只需要将dataType设置为jsonp即可
      success:function(data){                    
        console.log(data)
      }
    })
  })
</script>
2.getJson方式
<script>
  $.getJson(&#39;http://csdn.net/blog/data.java?callback=?&#39;,function(data){console.log(data)//处理返回的数据});
</script>
로그인 후 복사

window.name

在一个window的存活周期下,窗口载入的所有页面都共享一个window.name属性,每个页面都对它有可读可写的权限,即使window.location重载也不会有变化

window.name的格式为字符串,更多的时候我们使用json的格式来进行书写,window.name存在字符串的限制,最大的大小为2M

下面我们来举一个栗子:

a.html

  
      <input>
      <script>
          window.name="这是a网页设置的";
          document.getElementById("btn").onclick=function(){
              window.location.href="b.html"
          }
      </script>
  
로그인 후 복사

b.html

  
      <script>
          console.log(window.name);//"这是a网页设置的"
      </script>
  
로그인 후 복사
window.postMessage

这个方法和window.name一样,需要是同一个页面打开的窗口

我们直接来举一个栗子:

//数据端发送
<script>
//弹出一个新窗口
var myPopup = window.open(domain 
            + &#39;/windowPostMessageListener.html&#39;,&#39;myWindow&#39;);

//周期性的发送消息
setInterval(function(){
    var message = &#39;Hello!  The time is: &#39; + (new Date().getTime());
      var domain = &#39;http://scriptandstyle.com&#39;;
    console.log(&#39;blog.local:  sending message:  &#39; + message);
    myPopup.postMessage(message,domain);
  //postMessage有两个参数1.message代表的是要发送的数据
                       // 2.domain代表的是要发送数据到哪个地址
},6000);
</script>
//数据端接收
<script>
  //响应事件
window.addEventListener(&#39;message&#39;,function(event) {
    if(event.origin !== &#39;http://davidwalsh.name&#39;) return;
    console.log(&#39;message received:  &#39; + event.data,event);
    event.source.postMessage(&#39;holla back youngin!&#39;,event.origin);
},false);
  //需要注意的是1.需要对浏览器进行判断,众所周知IE使用的是attachEvent
  //这里注意message是postMessage的接收事件,其中有三个参数1.source,代表消息源,也就是发送消息的窗口
                                                      //2.origin,代表消息源的url,包含协议,端口,域名,用来验                                                       证数据源
                                                      //3.data,发送方发送过来的数据
</script>
로그인 후 복사

后台转换

这个方法是实际工作中最常用的,我们如果有需要跨域请求数据,一般会让后台配合请求到数据然后在返回给前台使用。

위 내용은 JavaScript 통신의 Ajax에 대한 자세한 소개(코드 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:segmentfault.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿