Ajax is what

Ajax is short for Asynchronous JavaScript and XML.

  • Asynchrony in Ajax: You can send requests asynchronously to the server without blocking the current page while waiting for a response, and the browser can do its own thing. The browser does not process the response data until the response is successfully retrieved.
  • XML (Extensible Markup Language) is a format for transmitting data in front – and back-end data communication. XML is not used much these days, but JSON is more commonly used.

Ajax is simply an asynchronous communication between the browser and the server.

Using Ajax, you can update parts of a page without reloading the entire page.

Basic usage of Ajax

XMLHttpRequest

Ajax, for asynchronous communication between the browser and the server, relies on XMLHttpRequest, which is a constructor.

Note: Neither XMLHttpRequest nor Ajax is bound to a specific data format.

Steps to use Ajax

  1. Create an XHR object

  2. Listen for events and process responses

    When the response is retrieved, the XHR object’s readyStatechange event is triggered, in which the response can be processed

    • readystatechangeEvent listenersreadyStateThis change in state
    • It has five states ranging from 0 to 4
    • 0: not initialized. Open () has not been called
    • 1: starts. Open () has been called, but send() has not been called
    • 2: send. Send () has been called, but no response has been received
    • 3: Receive. Partial response data has been received
    • 4: Done. All response data has been received and is ready for use in the browser

    The readyStatechange event can also be used with addEventListener, but note that Internet Explorer 6-8 does not support addEventListener

    For compatibility, this is not used in readyStatechange, but XHR is used directly

    For compatibility reasons, this is best placed before Open ()

  3. Prepare to send the request

    • Calling open() does not actually send the request, but merely prepares the request to be sent

      • The first parameter is HTTP methods GET, POST, PUT, and DELETE
      • The second parameter address URLhttps://www.baidu.com/search/suggest?words=js ./index.html ./index.xml ./index.txt
      • The third parameter is asynchronous true
  4. Send the request

    • Send () is called to formally send the request. Send () takes data carried through the request body

      • xhr.send(null) GET
      • xhr.send('username=alex&age=18') POST application/x-www-form-urlencoded
      • xhr.send(JSON.stringify({username:'xiaoliu'age:18})) POST application/JSON
Const url = "https://www.imooc.com/api/http/search/suggest?words=js" / / create the XHR object const XHR = new XMLHttpRequest () / / Xhr.onreadystatechange = () => {// If (xhr.readyState! // xhr.status: HTTP 200 404 // xhr.statusText: HTTP status OK Not Found the if ((XHR) status > = 200 && XHR. Status < 300) | | XHR. Status = = = 304) { console.log(xhr.responseText) // {"code":200,"data":[{"word":"jsp"},{"word":"js"},{"word":"json"},{"word":"js \ U5165 \ e "},{"word":" JSTL "}]} console.log(typeof xhr.responseText) // string}} // // use addEventListener to listen for events // Xhr.addeventlistener (' readyStatechange ', () => {}, false) xhr.open('GET', url, true) But in order to ensure compatibility, the proposal with XHR. Send (null) / / XHR finished loading: GET "https://www.imooc.com/api/http/search/suggest?words=js".Copy the code

A GET request

Carry data

GET requests cannot carry data through the request body, but they can carry data through the request header

const url = 'https://www.imooc.com/api/http/search/suggest?words=js&username=alex&age=18' const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr < 300) || xhr.status === 304) { console.log(xhr.responseText) } } Xhr. open('GET', url, true) xhr.send(null) // xhr.send('sex=male')Copy the code

When a GET request is made, the parameters are passed as a URL string, i.e.? The following string is its request parameter, delimited by &

Data encoding

If the data is not English letters, such as Chinese characters, it needs to be encoded and sent to the back end, otherwise it will cause garbled characters

EncodeURIComponent () can be used for encoding

Const url = ` https://www.imooc.com/api/http/search/suggest?words=${encodeURIComponent (' front end ')} `Copy the code

A POST request

Carry data

POST requests carry data primarily through the request body, but also through the request header

const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.responseText) } } Xhr.open ('POST', url, true) xhr.open('POST', url, true) xhr.send('username=alex&age=18')Copy the code

Data encoding

Xhr. send(' username = ${encodeURIComponent(' xcodeUricomponent ')}&age=18 ')Copy the code

JSON

What is the JSON

JSON is short for JavaScript Object Notation

Ajax is a format for sending and receiving data

Why do WE need JSON?

JSON comes in three forms, each of which is written like a JS data type and can be easily converted to and from a JS data type

Three forms of JSON

1. Simple value form

The simple value form of JSON corresponds to the underlying data types in JS

Numeric string Boolean null

 5
 ​
 "string"
 ​
 false
 ​
 null
Copy the code

Matters needing attention

① There is no undefined value in JSON

② The string in JSON must use double quotation marks

③ You can’t comment in JSON

2. Object form

JSON objects correspond to objects in JS

{" name ":" liu ", "age" : 18, "hobby" : / "reading", "painting", "family" : {" father ":" liu ", "mother", "the old yue"}}Copy the code

Matters needing attention

① The attribute name of the OBJECT in JSON must be quoted in double quotes, and the attribute value must be quoted in double quotes if it is a string

② Whenever a string is involved in JSON, double quotes must be used

③ Undefined is not supported

3. Array format

JSON arrays correspond to arrays in JS

[1, "hi," null] [{" id ": 1," username ":" liu ", "comment" : "666"}, {" id ": 2," username ":" note ", "comment" : "999"}]Copy the code

Matters needing attention

① Strings in arrays must be quoted in double quotes

② Whenever a string is involved in JSON, double quotes must be used

③ Undefined is not supported

Common methods of JSON

1.JSON.parse()

Json.parse () can parse jSON-formatted strings into JS values

It must be a valid JSON string, otherwise an error will be reported

const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(JSON.parse(xhr.responseText)) // {code: 200, data: {word: "jsp"},{word: "js"},{word: "json"},{word: "Introduction to js"}, {word: "JSTL"}} the console. The log (JSON. Parse (XHR. The responseText). Data) / / [{word: "JSP"}, {word: "js"}, {word: "Json "},{word: "js "},{word: "jstl"}] } } xhr.open('GET', 'https://www.imooc.com/api/http/search/suggest?words=js', true) xhr.send(null)Copy the code

2.JSON.stringify()

Json.stringify () converts basic JS data types, objects, or arrays into JSON-formatted strings

const xhr = new XMLHttpRequest() xhr.open('POST', 'https://www.imooc.com/api/http/search/suggest?words=js', True) xhr.send(json.stringify ({username: '小刘', age: 18}))Copy the code

3. Encapsulate localStorage with json.parse () and json.stringify ()

// encapsulate storage.js const storage = window.localStorage // set const set = (key, value) => {storage.setitem (key, Parse (storage.getitem (key))} // Remove const remove = key => {storage.removeitem (key)} // Clear const clear = () => {storage.clear()} export {set, get, remove, clear}Copy the code
Import {get, set, remove, clear} from './storage.js' set('username', 'liu') to the console. The log (get (" username ")) / / liu set (' zs, {name: 'zhang' age: 18}) console. The log (get) (' zs) / / {name: "zhang", the age: 18} remove('username') console.log(get('username')) // null clear() console.log(get('zs')) // nullCopy the code

First cross domain

1. What is cross-domain

Sending a request to a domain, if the domain to be requested is different from the current domain, is called cross-domain

A request between different domains is a cross-domain request

// Different domains, cross domains, // Access to XMLHttpRequest at 'https://www.baidu.com/' from origin 'http://127.0.0.1:5500' has been blocked by the browser CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. const url = 'https://www.baidu.com' const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.responseText) } } xhr.open('GET', url, true) xhr.send(null) // GET https://www.baidu.com/ net::ERR_FAILEDCopy the code

2. What are different domains and what are co-domains

HTTPS (protocol) :// www.baidu.com (domain) :443 (port number) /search (path)

Protocol, domain name, port number, any one is different, it is different domain

It doesn’t matter if path one is different

/ / different domain https://www.baidu.com/search http://www.baidu.com/search http://www.baidu.com/search http://m.baidu.com/search http://baidu.com/search https://www.baidu.com:443/search https://www.baidu.com:80/search / / with the domain name https://www.baidu.com/ https://www.baidu.com/searchCopy the code

3. Why are cross-domain requests blocked

Blocking cross-domain requests is actually a security policy of the browser itself – the same origin policy

The Same Origin Policy (SOP) is a convention introduced by Netscape into the browser in 1995. It is the core and most basic security function of the browser. Without the Same Origin policy, the browser is vulnerable to XSS and CSFR attacks. Same-origin means that the protocol, domain name, and port are the same. Even if two different domain names point to the same IP address, they are not same-origin.

No other client or server is blocked across domains

4. Cross-domain solutions

①CORS cross-domain resource sharing

(2) the json

Cross-domain resource sharing is preferred with CORS, and JSONP if the browser does not support CORS

CORS cross-domain resource sharing

1. The CORS is what

Setting is done through the back end, and the front end is only responsible for communication

Access-Control-Allow-Origin: *

Indicates that all domain names are allowed to request it across domains. * is a wildcard character without any restrictions

Only cross-domain requests with specified domain names are allowed

Access - Control - Allow - Origin: http://127.0.0.1:5500

2. Cross-domain process using CORS

① The browser sends a request

② Add the access-Control-allow-Origin header to the response header

③ The browser receives a response

(4) If the request is in the same domain, the browser does nothing extra, the back and forth communication is complete

⑤ If it is a cross-domain request, the browser will check whether cross-domain access is allowed in the response header

⑥ If cross-domain is allowed, communication is completed successfully

⑦ If the domain name you want to cross is not found or not included, the response result will be discarded

3. Compatibility with CORS

CORS can be used by Internet Explorer 10 or later

JSONP

1. The principle of the json

Script tags are not blocked by browsers across domains

JSONP basically uses script tags to load cross-domain files

2. Cross-domain implementation using JSONP

The JSONP interface is ready on the server

https://www.imooc.com/api/http/jsonp?callback=handleResponse

Load the JSONP interface dynamically

 const script = document.createElement('script')
 script.src = 'https://www.imooc.com/api/http/jsonp?callback=handleResponse'
 document.body.appendChild(script)
 ​
 const handleResponse = data => {
   console.log(data)
 }
Copy the code

Manually load the JSONP interface

 <script src="https://www.imooc.com/api/http/jsonp?callback=handleResponse"></script>
Copy the code

\

XHR properties

ResponseType and response properties

/ / 1. ResponseType and response const attribute url = 'https://www.imooc.com/api/http/search/suggest?words=js' const XHR = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return the if ((XHR. Status > = 200 && XHR. Status < 300) | | XHR. Status = = = 304) {/ / response in the form of text content / / the responseText can only be not set Log ('responseText:', 'console.log ',' responseType :') xhr.responseText) //ajax.js:11 Uncaught DOMException: Failed to read the 'responseText' property from 'XMLHttpRequest': The value is only accessible if The object's 'responseType' is' or 'text' (was 'json'). // Can be used instead of responseText console.log('response:', xhr.response) // {code: 200, data: Array(5)}, a string in json format. Parse (json.parse (xhr.responsetext))}} xhr.open('GET', url, // xhr.responseType = 'text' xhr.responseType = 'json' // set to json format, Xhr. send(null) // Internet Explorer 6 to 9 is not supported, but Internet Explorer 10 is supportedCopy the code

Xhr.responsetext is used when setting response=’json’

2. The timeout attribute

Setting the timeout period of the request (ms)

const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) } } Xhr. open('GET', url, true) xhr.timeout = 5 // Xhr. send(null) // XHR failed loading: GET "https://www.imooc.com/api/http/search/suggest?words=js". / / 6 ~ 7 is not supported, IE8 to supportCopy the code

3. The withCredentials attribute

Specifies whether cookies are carried when requests are sent using Ajax

Sending requests using Ajax, by default, carries cookies when in the same domain; Across domains, no

xhr.withCredentials = true

Ultimately, the success of cross-domain Cookie portability depends on whether the server agrees or not

const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) //Access to XMLHttpRequest at 'https://www.imooc.com/api/http/search/suggest?words=js' from origin' http://127.0.0.1:5500 'has had blocked by CORS policy: The value of the 'Access-Control-Allow-Origin' header in the response must not be the wildcard '*' when the request's credentials mode is 'include'. The credentials mode of requests initiated by the XMLHttpRequest is controlled by the WithCredentials attribute.}} xhr.open('GET', URL, true) xhr.withCredentials = true xhr.send(null) // IE6 to 9 are not supported, IE10 support is availableCopy the code

The server disagreed and failed to carry the packet

XHR method

1.abort()

Abort the current request

Typically used with the ABORT event

const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) } } xhr.open('GET', url, true) xhr.send(null) // XHR failed loading: GET "https://www.imooc.com/api/http/search/suggest?words=js". xhr.abort()Copy the code

2.setRequestHeader()

Request header information can be set

Xhr.setrequestheader (name of the header field, value of the header field)

// const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const url = 'https://www.imooc.com/api/http/json/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.onreadystatechange = () => { if (xhr.readyState ! = 4) return if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) // {"code":200,"data":[{"word":"jsp"},{"word":"js"},{"word":"json"},{"word":"js \u5165\u95e8"},{"word":"jstl"}]} } } Xhr.open ('POST', url, true) // The content-type field in the request header tells the server, // xhr.setrequesTheader (' content-type ', 'application/x-www-form-urlencoded') xhr.setRequestHeader('Content-Type', 'application/json') // xhr.send(null) xhr.send(' username=${decodeURIComponent(' decodeURIComponent ')}&age=18 ') xhr.send(json. Username: 'Zhang' // ajax.js:21 XHR finished loading: POST "https://www.imooc.com/api/http/json/search/suggest?words=js"}) / / at the back of the send is ignored, this test two types respectively)Copy the code

When content-Type is set to Application /x-www-form-urlencoded:

Request Headers

Setting content-Type to Application /json does not change the server interface:

Request Headers

With content-type set to Application /json, change to JSON interface:

\

XHR event

1. The load event

Triggered when response data is available

const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.onload = () => {// When the response is available, Don't need to judge the readyState is 4 the if ((XHR) status > = 200 && XHR. Status < 300) | | XHR. Status = = = 304) {the console. The log (XHR. Response) //{"code":200,"data":[{"word":"jsp"},{"word":"js"},{"word":"json"},{"word":"js \u5165\u95e8"},{"word":"jstl"}]} } } // xhr.addEventListener( // 'load', // () => { // if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { // console.log(xhr.response) // } // }, // false // ) xhr.open('GET', url, true) xhr.send(null) // ajax.js:22 XHR finished loading: GET "https://www.imooc.com/api/http/search/suggest?words=js". / / 6 ~ 8 does not support the load eventCopy the code

2. Error event

Triggered when a request error occurs

// const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const url = 'https://www.iimooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.addEventListener( 'load',  () => { if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) } }, false ) xhr.addEventListener( 'error', () => { console.log('error') //error }, false ) xhr.open('GET', url, true) xhr.send(null) //GET https://www.iimooc.com/api/http/search/suggest?words=js net::ERR_TUNNEL_CONNECTION_FAILED // IE10 support is availableCopy the code

3. Abort event

Triggered when abort() is called to terminate the request

const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.addEventListener( 'load', () => { if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) } }, false ) xhr.addEventListener( 'abort', () => { console.log('abort') // abort }, false ) xhr.open('GET', url, true) xhr.send(null) // ajax.js:26 XHR failed loading: GET "https://www.imooc.com/api/http/search/suggest?words=js". The XHR. Abort () / / build is started to supportCopy the code

4. A timeout event

Triggered after the request timed out

const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = new XMLHttpRequest() xhr.addEventListener( 'load', () => { if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) // } }, false ) xhr.addEventListener( 'timeout', () => { console.log('timeout') // timeout }, false ) xhr.open('GET', url, true) xhr.timeout = 5 xhr.send(null) // XHR finished loading: GET "https://www.imooc.com/api/http/search/suggest?words=js". / / IE8 to supportCopy the code

If the timeout time is too small, the XHR will timeout and fail to be loaded

FormData

Can be used to send form data; It can also be used independently of forms to send key-value pair data.

Internet Explorer 10 and later are supported

1. Submit the form using Ajax

const login = document.getElementById('login') const { username, password } = login const btn = document.getElementById('submit') const url = 'https://www.imooc.com/api/http/search/suggest?words=js' btn.addEventListener( 'click', E => {// prevent form auto-submission e.preventDefault() // Form data validation // omitted... // Send Ajax request const XHR = new XMLHttpRequest() xhr.addeventListener ('load', () => { if ((xhr.status >= 200 && xhr.status < 300) || xhr.status === 304) { console.log(xhr.response) } }, false ) xhr.open('POST', url, Const data = 'username=${username. Value}&password=${password.value}' // FormData can be used to send FormData // const data =  new FormData(login) // data.append('age', 18) // data.append('sex', 'male') // console.log(data) // for (const item of data) { // console.log(item) // } xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded') xhr.send(data) // xhr.send('username=alex&password=12345') }, false )Copy the code

2. Basic usage of FormData

// Create a FormData object with HTML form elements const fd = new FormData(form elements) // Add data with append() method const fd = new FormData(form elements) Fd.append ('age', 18) fd.append('sex', 'male') // Xhr.send (FormData)Copy the code

Encapsulating AJAX (Learn from)

index.html

<! DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, Initial =1.0" /> <title> </head> <body></body> <script type="module"> import {Ajax, get, getJSON, post } from './ajax/index.js' const url = 'https://www.imooc.com/api/http/search/suggest?words=js' const xhr = ajax(url, {method: 'GET', params: {username: 'responseType ', data: {age: 18}, responseType: 'json', success(response) { console.log(response) }, httpCodeError(err) { console.log('http code error', err) }, error(xhr) { console.log('error', xhr) }, abort(xhr) { console.log('abort', xhr) }, timeout(xhr) { console.log('timeout', xhr) } }) xhr.abort() </script> </html>Copy the code

ajax.js

// constant import {HTTP_GET, CONTENT_TYPE_FORM_URLENCODED, CONTENT_TYPE_JSON} from './constants. Js' // Utility functions import {serialize, addURLData, SerializeJSON} from './utils. Js' // import DEFAULTS from './defaults.js' // Ajax class class Ajax {constructor(url, options) { this.url = url this.options = Object.assign({}, DEFAULTS, Options) // initialize this.init()} // Initialize init() {const XHR = new XMLHttpRequest() this.xhr = XHR // bind the response event handler this.bindEvents() xhr.open(this.options.method, this.url + this.addParam(), SetCookie () // setTimeout this.settimeout () // send the request BindEvents () {const XHR = this.xhr const {success, httpCodeError, error, abort, timeout } = this.options // load xhr.addEventListener( 'load', () => { if (this.ok()) { success(xhr.response, XHR)} else {httpCodeError(xhr.status, XHR)}}, false) Xhr.addeventlistener ('error', () => {error(XHR)}, false) // Abort xhr.addeventListener ('abort', () => { abort(xhr) }, false ) // timeout xhr.addEventListener( 'timeout', () => { timeout(xhr) }, False)} / / check whether the HTTP status code of the response normal ok () {const XHR = this. XHR return (XHR) status > = 200 && XHR. Status < 300) | | XHR) status AddParam () {const {params} = this.options if (! params) return '' return addURLData(this.url, Serialize (params)} / / set responseType setResponseType () {this. XHR. ResponseType = this. The options. The responseType} / / Sets whether cross-domain carry cookies setCookie () {if (this. Options. WithCredentials) {this. XHR. WithCredentials = true}} / / set the timeout SetTimeout () {const {timeoutTime} = this.options if (timeoutTime > 0) {this.xhr.timeout = timeoutTime}} // Send the request sendData() { const xhr = this.xhr if (! This.issenddata ()) {return xhr.send(null)} let resultData = null const {data} = this.options // Send FormData if (this isFormData ()) = {resultData data} else if (this. IsFormURLEncodedData ()) {/ / send This.setcontenttype (CONTENT_TYPE_FORM_URLENCODED) resultData = serialize(data)} Application /x-www-form-urlencoded data this.setContentType(content_type_urlencoded) resultData = serialize(data)} Else if (this.isjsonData ()) {// Send application/json format data this.setContentType(CONTENT_TYPE_JSON) resultData = SerializeJSON (data)} else {// Send data in other formats this.setContentType() resultData = data} xhr.send(resultData)} // Whether to use it IsSendData () {const {data, method} = this.options if (! Data) return false if (method.tolowerCase () === http_get.tolowerCase ()) return false return true} // Whether to send FormData IsFormData () {return this.options.data instanceof FormData} // Whether to send application/x-www.form-urlencoded isFormURLEncodedData() { return this.options.contentType.toLowerCase().includes(CONTENT_TYPE_FORM_URLENCODED) } // Whether need to send application/json data format isJSONData () {return this. The options. The contentType. ToLowerCase. Includes (CONTENT_TYPE_JSON)} ContentType setContentType(contentType = this.options. ContentType) {if (! contentType) return this.xhr.setRequestHeader('Content-Type', GetXHR () {return this.xhr}} export default AjaxCopy the code

index.js

import Ajax from './ajax.js' const ajax = (url, options) => { return new Ajax(url, options).getXHR() } const get = (url, options) => { return ajax(url, { ... options, method: 'GET' }) } const getJSON = (url, options) => { return ajax(url, { ... options, method: 'GET', responseType: 'json' }) } const post = (url, options) => { return ajax(url, { ... options, method: 'POST' }) } export { ajax, get, getJSON, post }Copy the code

defaults.js

// Import {HTTP_GET, CONTENT_TYPE_FORM_URLENCODED} from './constants. Js' // Const DEFAULTS = {method: // params: {// username: ' ', // age: 18 //} data: Null, // data: {// username: ' ', // age: 18 //} // data: FormData contentType: CONTENT_TYPE_FORM_URLENCODED, responseType: '', timeoutTime: 0, withCredentials: False, // Abort () {}, httpCodeError() {}, error() {}, abort() {}, timeout() {}} export default DEFAULTSCopy the code

utils.js

Const serialize = param => {const results = [] for (const [] key, value] of Object.entries(param)) { results.push(`${encodeURIComponent(key)} = ${decodeURIComponent(value)}`) } // ['username= liu ','age=18'] return results.join('&')} // Serialize data to a JSON string const serializeJSON = param => {return JSON. Stringify (param)} // add parameters to URL // www.baidu.com? Search =js& const addURLData = (URL, data) => {if (! data) return '' const mark = url.includes('? ')? '&' : '? ' return `${mark}${data}` } export { serialize, addURLData, serializeJSON }Copy the code

constants.js

// export const HTTP_GET = 'GET' export const CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded' export const CONTENT_TYPE_JSON = 'application/json'Copy the code

Transform packaged Ajax with Promise (learn from)

index.html

<! DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, Initial =1.0" /> <title> </head> <body></body> <script type="module"> import {Ajax, get, getJSON, post } from './ajax/index.js' const url = 'https://www.imooc.com/api/http/search/suggest?words=js' // const xhr = Ajax (url, {/ / method: 'GET', / / params: {the username: 'note:'}, / / data: 18 / /} {/ / age:, / / responseType: 'json', // success(response) { // console.log(response) // }, // httpCodeError(err) { // console.log('http code error', err) // }, // error(xhr) { // console.log('error', xhr) // }, // abort(xhr) { // console.log('abort', xhr) // }, // timeout(xhr) { // console.log('timeout', xhr) // } // }) // xhr.abort() const p = getJSON(url, { params: { username: }, data: {age: 18}, timeoutTime: 10 }) p.xhr.abort() const { ERROR_HTTP_CODE, ERROR_REQUEST, ERROR_TIMEOUT, ERROR_ABORT } = p p.then(response => { console.log(response) }).catch(err => { switch (err.type) { case ERROR_HTTP_CODE:  console.log(err.text) break case ERROR_REQUEST: console.log(err.text) break case ERROR_TIMEOUT: console.log(err.text) break case ERROR_ABORT: console.log(err.text) break } }) </script> </html>Copy the code

index.js

import Ajax from './ajax.js' import { ERROR_HTTP_CODE, ERROR_REQUEST, ERROR_TIMEOUT, ERROR_ABORT, ERROR_HTTP_CODE_TEXT, ERROR_REQUEST_TEXT, ERROR_TIMEOUT_TEXT, ERROR_ABORT_TEXT } from './constants.js' const ajax = (url, options) => { // return new Ajax(url, options).getXHR() let xhr const p = new Promise((resolve, reject) => { xhr = new Ajax(url, { ... options, ... { success(response) { resolve(response) }, httpCodeError(status) { reject({ type: ERROR_HTTP_CODE, text: `${ERROR_HTTP_CODE_TEXT}:${status}` }) }, error() { reject({ type: ERROR_REQUEST, text: `${ERROR_REQUEST_TEXT}` }) }, abort() { reject({ type: ERROR_ABORT, text: `${ERROR_ABORT_TEXT}` }) }, timeout() { reject({ type: ERROR_TIMEOUT, text: `${ERROR_TIMEOUT_TEXT}` }) } } }).getXHR() }) p.xhr = xhr p.ERROR_HTTP_CODE = ERROR_HTTP_CODE p.ERROR_REQUEST = ERROR_REQUEST p.ERROR_ABORT = ERROR_ABORT p.ERROR_TIMEOUT = ERROR_TIMEOUT return p } const get = (url, options) => { return ajax(url, { ... options, method: 'GET' }) } const getJSON = (url, options) => { return ajax(url, { ... options, method: 'GET', responseType: 'json' }) } const post = (url, options) => { return ajax(url, { ... options, method: 'POST' }) } export { ajax, get, getJSON, post }Copy the code

constants.js

// export const HTTP_GET = 'GET' export const CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded' export const CONTENT_TYPE_JSON = 'application/json' export const ERROR_HTTP_CODE = 1 export const ERROR_HTTP_CODE_TEXT = 'ABNORMAL HTTP status code' export const ERROR_REQUEST = 2 export const ERROR_REQUEST_TEXT = 'Request blocked' export const ERROR_TIMEOUT = 3 Export const ERROR_TIMEOUT_TEXT = 'Request timeout' export const ERROR_ABORT = 4 export const ERROR_ABORT_TEXT = 'Request aborted'Copy the code

Reference:

The front end of MOOCs