美文网首页
AJAX和JSON

AJAX和JSON

作者: jackie季 | 来源:发表于2018-08-29 20:16 被阅读0次

浏览器和服务器之间,是通过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中的对象

相关文章

  • ajax 的实现

    var $ = {}; $.ajax = ajax; function json2url(json){ var a...

  • AJAX和JSON

    第一章Ajax 1.1 Ajax 概念 "Asynchronous Javascript And XML"(异步...

  • JSON和ajax

    json json是类似于javascript对象的一种数据格式; json格式的数据: {"name":'tom...

  • AJAX和JSON

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

  • json和ajax

    json json是 JavaScript Object Notation 的首字母缩写,单词的意思是javasc...

  • ajax和json

    ajax介绍 问题:用户注册的时候,没有,用户名是否可用提示,导致用户需要反复的提交表单,用户体验不好。优化:用户...

  • json 和ajax

    json json是 JavaScript Object Notation 的首字母缩写,单词的意思是javasc...

  • AJAX和JSON

    AJAX: 1. 概念: ASynchronous JavaScript And XML 异步的JavaSc...

  • JSON和AJAX

    JSON 一、介绍 JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量...

  • 12_django_ajax

    AJAX 一、什么是ajax? 异步的JavaScript和xml,跟后台交互,都用json 二、ajax干啥用的...

网友评论

      本文标题:AJAX和JSON

      本文链接:https://www.haomeiwen.com/subject/xcikwftx.html