AJAX 学习笔记

AJAX 简介

全称为 Asynchronous JavaScript And XML,就是异步的 JS 和 XML。
通过 AJAX 可以在浏览器中向服务器发送异步请求。
AJAX 不是新的编程语言,而是一种将现有的标准组合在一起使用的新方式。

AJAX 特点

  1. 优点

    1)可以无需刷新页面而与服务器端进行通信。
    2)允许你根据用户事件来更新部分页面内容。

  2. 缺点

    1)没有浏览历史,不能回退
    2) 存在跨域问题(同源)
    3) SEO 不友好

AJAX 的使用

XMLHttpRequest,AJAX 的所有操作都是通过该对象进行的。

  1. 使用步骤

    1)创建 XMLHttpRequest 对象

    var xhr = new XMLHttpRequest();
    

    2)设置请求信息

    xhr.open(method, url);
    //可以设置请求头,一般不设置
    

    3)发送请求

    xhr.send(body) 
    //get 请求不传 body 参数,只有 post 请求使用
    

    4)接收响应

    //xhr.responseXML 接收 xml 格式的响应数据
    //xhr.responseText 接收文本格式的响应数据
    xhr.onreadystatechange = function (){
      if(xhr.readyState == 4 && xhr.status == 200){
         var text = xhr.responseText;
         console.log(text);
       }
    }
    
  2. 解决 IE 缓存问题
    问题:
    在一些浏览器中(IE),由于缓存机制的存在,在请求url地址不变的情况下,ajax 只会发送的第一次请求,剩余多次请求不会在发送给浏览器而是直接加载缓存中的数据。

    解决方式:
    1)浏览器的缓存是根据 url 地址来记录的,所以我们只需要修改 url 地址
    即可避免缓存问题,即可在url末尾添加时间戳

    xhr.open("get","/testAJAX?t="+Date.now());
    

    2)在请求头添加参数,禁止浏览器缓存

    'Cache-Control':'no-cache',
    'Pragma': 'no-cache',
    
  3. AJAX 请求状态
    xhr.readyState 可以用来查看请求当前的状态
    XMLHttpRequest.readyState
    在这里插入图片描述

  4. jQuery 中的 AJAX

    $.method(url, [data], [callback], [type])
    method: get , post 等
    url:请求的 URL 地址。
    data:请求携带的参数。
    callback:载入成功时回调函数。
    type:设置返回内容格式,xml, html, script, json, text, _default。

跨域

同源策略

同源策略(Same-Origin Policy)最早由 Netscape 公司提出,是浏览器的一种安全策略。违背同源策略就是跨域。
同源: 协议、域名、端口号 必须完全相同。

跨域解决办法 —— 参考文章

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值