The difference between ajax and fetch: 1. The development architecture of ajax based on native XHR is not clear, and fetch uses Promise’s asynchronous processing mechanism, which is simpler to use than ajax; 2. ajax uses the XMLHttpRequest object to request data, and fetch is only global A way to measure the window.
The operating environment of this article: windows7 system, javascript1.8.5&&html5 version, Dell G3 computer.
What is the difference between ajax and fetch
1. The difference between ajax and fetch:
(1), ajax uses the XMLHttpRequest object to request data, and fetch is a method of window
(2), ajax is developed based on native XHR, the structure of XHR itself is not clear, and fetch is already available Alternatives
(3). Compared with ajax, fetch has a better and more convenient writing method
(4). fetch only reports errors for network requests, and treats 400 and 500 as successful requests. , need to be encapsulated to handle
(5), fetch has no way to natively monitor the progress of the request, and XHR can
2.ajax usage
because Its native writing method is very useless, so most of them will be encapsulated, which may lead to many people not being able to write an ajax request by themselves. They all use JQuery or Axios to request data.
var xhr= new XMLHttpRequest(); // 新建XMLHttpRequest对象xhr.onload= function(){ //请求完成 console.log(this.responseText); }// 发送请求:xhr.open('GET', '/user'); xhr.send();
Such a request is sent out. It's very troublesome. You have to write so many lines of code to send a simple request. Of course you won't write it like this in actual development, otherwise the code will be redundant and readable. Use promise to encapsulate it
var Ajax = { get: function(url,fn){ // XMLHttpRequest对象用于在后台与服务器交换数据 var xhr=new XMLHttpRequest(); xhr.open('GET',url,false); xhr.onreadystatechange=function(){ // readyState == 4说明请求已完成 if(xhr.readyState==4){ if(xhr.status==200 || xhr.status==304){ console.log(xhr.responseText); fn.call(xhr.responseText); } } } xhr.send(); }, // data应为'a=a1&b=b1'这种字符串格式,在jq里如果data为对象会自动将对象转成这种字符串格式 post: function(url,data,fn){ var xhr=new XMLHttpRequest(); xhr.open('POST',url,false); // 添加http头,发送信息至服务器时内容编码类型 xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); xhr.onreadystatechange=function(){ if (xhr.readyState==4){ if (xhr.status==200 || xhr.status==304){ // console.log(xhr.responseText); fn.call(xhr.responseText); } } } xhr.send(data); } }
Code comments:
1.open(method, url, async) method required Three parameters:
method: The method used to send the request (GET or POST); compared with POST, GET is simpler and faster, and can be used in most cases; however, in the following In this case, please use POST request:
①Unable to use cache files (update files or databases on the server)
②Send a large amount of data to the server (POST has no data volume limit)
③Send a message containing When user input of unknown characters, POST is more stable and reliable than GET
url: Specifies the URL of the server-side script (the file can be any type of file, such as .txt and .xml, or a server script file , such as .asp and .php (can perform tasks on the server before returning the response));
async: Specifies that the request should be processed asynchronously (true) or synchronously (false); true is when Execute other scripts while waiting for the server response, and process the response when the response is ready; false means wait for the server response before executing.
2.send() method can send the request to the server.
3.onreadystatechange: There is a function that handles the server response. Whenever readyState changes, the onreadystatechange function will be executed.
4.readyState: Stores the status information of the server response.
0: The request is not initialized (the proxy is created, but the open() method has not been called)
1: The server connection has been established (the open method has been called)
2: The request has been received (send The method has been called, and the header and status are available)
3: The request is being processed (downloading, the responseText attribute already contains part of the data)
4: The request has been completed, and the response is ready (the download operation has Completed)
5.responseText: Get the response data in string form.
6.setRequestHeader(): When POST transmits data, it is used to add HTTP headers, then send(data), pay attention to the data format; when GET sends information, just add parameters directly to the url, such as url?a =a1&b=b1.
3.fetch usage
1. The first parameter is the URL
2. The optional second parameter can control different init objects
3. Use the promise object in js
var arr1 = [{ name: "haha", detail:"123"}]; fetch("url", { method: "post", headers: {//设置请求的头部信息 "Content-Type": "application/json" //跨域时可能要加上 //"Accept":"allication/json" }, //将arr1对象序列化成json字符串 body: JSON.stringify(arr1)//向服务端传入json数据 }).then(function(resp) { resp.json().then((data) => { }) });
All IE browsers will not support the fetch() method, and the server will not reject when returning status code 400 500
【 Related tutorial recommendations: AJAX video tutorial】
The above is the detailed content of What is the difference between ajax and fetch. For more information, please follow other related articles on the PHP Chinese website!

React is a JavaScript library for building modern front-end applications. 1. It uses componentized and virtual DOM to optimize performance. 2. Components use JSX to define, state and attributes to manage data. 3. Hooks simplify life cycle management. 4. Use ContextAPI to manage global status. 5. Common errors require debugging status updates and life cycles. 6. Optimization techniques include Memoization, code splitting and virtual scrolling.

React's future will focus on the ultimate in component development, performance optimization and deep integration with other technology stacks. 1) React will further simplify the creation and management of components and promote the ultimate in component development. 2) Performance optimization will become the focus, especially in large applications. 3) React will be deeply integrated with technologies such as GraphQL and TypeScript to improve the development experience.

React is a JavaScript library for building user interfaces. Its core idea is to build UI through componentization. 1. Components are the basic unit of React, encapsulating UI logic and styles. 2. Virtual DOM and state management are the key to component work, and state is updated through setState. 3. The life cycle includes three stages: mount, update and uninstall. The performance can be optimized using reasonably. 4. Use useState and ContextAPI to manage state, improve component reusability and global state management. 5. Common errors include improper status updates and performance issues, which can be debugged through ReactDevTools. 6. Performance optimization suggestions include using memo, avoiding unnecessary re-rendering, and using us

Using HTML to render components and data in React can be achieved through the following steps: Using JSX syntax: React uses JSX syntax to embed HTML structures into JavaScript code, and operates the DOM after compilation. Components are combined with HTML: React components pass data through props and dynamically generate HTML content, such as. Data flow management: React's data flow is one-way, passed from the parent component to the child component, ensuring that the data flow is controllable, such as App components passing name to Greeting. Basic usage example: Use map function to render a list, you need to add a key attribute, such as rendering a fruit list. Advanced usage example: Use the useState hook to manage state and implement dynamics

React is the preferred tool for building single-page applications (SPAs) because it provides efficient and flexible ways to build user interfaces. 1) Component development: Split complex UI into independent and reusable parts to improve maintainability and reusability. 2) Virtual DOM: Optimize rendering performance by comparing the differences between virtual DOM and actual DOM. 3) State management: manage data flow through state and attributes to ensure data consistency and predictability.

React is a JavaScript library developed by Meta for building user interfaces, with its core being component development and virtual DOM technology. 1. Component and state management: React manages state through components (functions or classes) and Hooks (such as useState), improving code reusability and maintenance. 2. Virtual DOM and performance optimization: Through virtual DOM, React efficiently updates the real DOM to improve performance. 3. Life cycle and Hooks: Hooks (such as useEffect) allow function components to manage life cycles and perform side-effect operations. 4. Usage example: From basic HelloWorld components to advanced global state management (useContext and

The React ecosystem includes state management libraries (such as Redux), routing libraries (such as ReactRouter), UI component libraries (such as Material-UI), testing tools (such as Jest), and building tools (such as Webpack). These tools work together to help developers develop and maintain applications efficiently, improve code quality and development efficiency.

React is a JavaScript library developed by Facebook for building user interfaces. 1. It adopts componentized and virtual DOM technology to improve the efficiency and performance of UI development. 2. The core concepts of React include componentization, state management (such as useState and useEffect) and the working principle of virtual DOM. 3. In practical applications, React supports from basic component rendering to advanced asynchronous data processing. 4. Common errors such as forgetting to add key attributes or incorrect status updates can be debugged through ReactDevTools and logs. 5. Performance optimization and best practices include using React.memo, code segmentation and keeping code readable and maintaining dependability


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Dreamweaver CS6
Visual web development tools