AJAX和JSON

浏览器和服务器之间,是通过HTTP协议通信的,那么如何发出一个HTTP请求呢,有以下几种方法:

方式 请求 缺点
form get/post 会刷新或新打开一个页面
a标签 get 会刷新或新打开一个页面
img标签 get 只能以图片形式展现
link标签 get 只能以css或favicon形式展现
script标签 get 只能以脚本形式运行

以上方法要么就只能以get方式发出请求,要么就会刷新页面,那如何能够使用两种方式请求又不会刷新页面呢?那就是AJAX

AJAX(Asynchronous JavaScript And XML)指的是通过JavaScript的异步通信,从服务器中获取数据,再更新当前页面部分,不用刷新整个网页
包括以下四个步骤:

  1. 创建XMLHttpRequest实例对象
  2. 发出HTTP请求
  3. 服务器返回数据
  4. 解析并更新局部页面

用法:
XMLHttpRequest是一个构造函数,可以使用new命令生成实例对象:
let request= new XMLHttpRequest()
生成实例之后可以使用open()方法发送请求,参数必须包括请求方式和URL:
request.open('GET', '/xxx')
通过send()方法发送数据,参数可以为空:
request.send(data)
我们需要监听通信状态,通过readyState属性,一旦状态变化就会触发readystatechange事件:
request.onreadystatechange = function () {}

完整的写法:

    let request = new XMLHttpRequest()
    request.open('get', '/xxx')
    request.send()
    request.onreadystatechange = () => {
        if (request.readyState === 4) {
            if (request.status >= 200 && request.status < 300) {
                console.log('请求成功')
                console.log(request.responseText)
            } else {
                console.log('请求失败')
            }
        }
    }

XMLHttpRequest实例属性

readyState
onreadystatechange
response
responseType
responseText
responseXML
responseURL
status
statusText

XMLHttpRequest实例方法

open()
send()
setRequestHeader()
getResponseHeader()
getAllResponseHeaders()
abort()

注意,AJAX 只能向同源网址(协议、域名、端口都相同)发出 HTTP 请求,如果发出跨域请求,就会报错。
跨域解决方案:CORS(Cross-Origin Resource sharing 跨源资源分享)

JSON

现在,服务器返回的大多是 JSON 格式的数据,很少使用 XML 格式。JSON是一门语言,是一种轻量级的数据交换格式。
JSON模仿了JS的数据类型与结构,其中数据类型没有function和undefined,其它的与JS一样。结构包括两种:无序的“键/值”对的集合(类似对象),值的有序列表(类似数组)

    response.setHeader('content-Type', 'text/json;charset=utf-8')
    response.end(`
    {
      "note":{
        "to": "A",
        "from": "B",
        "heading": "打招呼",
        "content": "hi"
      }
    }
    `)

注意:JSON中的string类型必须用双引号括起来
JSON.parse() 用于将符合JSON语法的字符串转换为JS中的对象

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,374评论 19 139
  • Ajax: 允许加载数据而无需刷新整个页面 Ajax 采用异步( 或称非阻塞 )处理模型, 所以浏览器在等待数据加...
    EmileSu_大苏阅读 1,365评论 0 0
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 28,018评论 1 45
  •   2005 年,Jesse James Garrett 发表了一篇在线文章,题为“Ajax: A new App...
    霜天晓阅读 4,367评论 0 1
  • 远远的望着你望着你的背影美丽心里默念着你明媚的眼眸里有我路灯亮的烁眼天空下起雨我渴望自己快步走去为你遮蔽这风雨 茂...
    HowardVeen阅读 1,371评论 0 0