AJAX全称为 Asynchronous Javasript And XML,是在浏览器端进行网络编程(发送请求,接收响应)的技术方案。AJAX 也就是浏览器提供的一套API,可以供 Javascript 调用,从而通过代码来控制请求和响应,实现网络编程。

AJAX 使用基本模板

使用 AJAX 的过程相当于访问一个页面

     // 1.创建一个 XMLHttpRequest 的对象(相当于打开了一个浏览器)
     // 兼容方案
     var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");
// 2,输入网址(get或post 根据需求设置,一般参数通过url传递则使用 get, 关于账户密码等敏感信息使用 post)
xhr.open('get', 'time.php');
// 3.敲回车,开始请求
// 因为响应需要时间,所以无法通过返回值的方式返回响应
// var response = xhr.send();
// console.log(response);
xhr.send();
// 3.等待响应
xhr.addEventListener('readystatechange', function () {
if (this.readyState === 4) {
// 获取响应体
console.log(this.responseText);
}
});

详解等待状态(readyState)

 readyState 状态描述 含义
0 unsent 初始化,请求了一个代理对对象,
1 opened open()方法已经调用,建立一个与服务端特定端口的连接
2 header_receive 已经接收到了响应头,但是还没有接收响应体
3 loading 正在下载响应体
4 done 响应体下载完成,可以直接使用 responseText

遵循HTTP

var xhr = new XMLHttpRequest();

        // 设置请求行
xhr.open('get', 'time.php'); // 设置请求头
xhr.setRequestHeader('Accept', 'text/plain'); // 设置请求体
xhr.send(null); xhr.addEventListener('readystatechange', function () {
if (this.readyState === 4 && this.status === 200) { // 获取响应状态码
console.log(this.status); // 获取响应状描述
console.log(this.statusText); // 获取响应头信息
console.log(this.getResponseHeader('Content-Type')); // 指定响应头
console.log(this.getAllResponseHeaders()); // 全部响应头 // 转换成数组
console.log(this.getAllResponseHeaders().split("\n")); // 获取响应头中的某一个信息
console.log(this.getResponseHeader('server')); }
});

同步与异步

同步:在同一时刻只能做同一件事,在执行一些耗时的事情时不去做其他事情,而是等待

异步:在执行一些耗时的事情是去做其他事情,而不是等待(性能更好,默认为 true)

同步:

                console.time('ajax同步');
const xhrSync = new XMLHttpRequest();
xhrSync.open('get', 'time.php', false);
xhrSync.send(); // 同步代码会卡在 send() 这里
console.log(xhrSync.responseText);
console.timeEnd('ajax同步');

异步:

// 异步性能更好,时间更短
console.time('ajax异步');
const xhr = new XMLHttpRequest();
     // 这里 第三个参数默认为 true,即不写true时为异步(大多数使用)
xhr.open('get', 'time.php', true);
xhr.send();
console.log(xhr.responseText);
console.timeEnd('ajax异步');

AJAX 初识的更多相关文章

  1. day059 ajax初识 登录认证练习

    ajax初识 ajax有两个特点: 一个是异步,另一个是浏览器页面局部刷新(这个特点是用户感受不到的时候进行的) 示例: 页面输入两个整数,通过AJAX传输到后端计算结果并返回 在HTML文件中: & ...

  2. Ajax—初识

    看DRP的过程.又一次学习了一遍Ajax.更深刻的体会到了Ajax所具有的魅力.Ajax是一种技术或者方法,更是一 种艺术.它让我们的程序以一种更完美的姿态呈如今用户面前.以下就让我们一起走进Ajax ...

  3. 70、django之Ajax初识

    Ajax准么说是用于Javascript与服务器端进行交互的,我们之前呢没有了解ajax也同样可以完成与服务器的交互,那么ajax的优势在哪里?首先ajax是异步交互的也就是说我们基本不会遇到卡顿现象 ...

  4. AJAX初识(原生JS版AJAX和Jquery版AJAX)

    一.什么是JSON 1.介绍 JSON独立于语言,是一种与语言无关的数据格式. JSON指的是JavaScript对象表示法(JavaScript Object Notation) JSON是轻量级的 ...

  5. day059-60 ajax初识 登录认证练习 form装饰器, form和ajax上传文件 contentType

    一.ajax 的特点 1.异步交互:客户端发出一个请求后,需要等待服务器响应结束后, 才能发出第二个请求 2.局部刷新:给用户的感受是在不知不觉中完成请求和响应过程. 二.ajax 模板示例 ($.a ...

  6. django之Ajax初识

    Ajax准么说是用于Javascript与服务器端进行交互的,我们之前呢没有了解ajax也同样可以完成与服务器的交互,那么ajax的优势在哪里?首先ajax是异步交互的也就是说我们基本不会遇到卡顿现象 ...

  7. jQuery的Ajax初识

    1. 什么是Ajax? Ajax是“Asynchronous Javascript And XML(异步Javascript和XML)”的缩写, 是指一种创建交互式网页应用的网站开发技术. Ajax不 ...

  8. Django - Ajax初识

    当需要在弹出的对话框中,做判断操作时,需要用到ajax 1.host.html <!DOCTYPE html><html lang="en"><hea ...

  9. ajax初识

    Ajax 全称为:"Asynchronous JavaScript and XML"(异步 JavaScript 和 XML) 它并不是 JavaScript 的一种单一技术,而是 ...

随机推荐

  1. [C++] new和delete运算符使用方法

    new 和 delete 是C++语言中的两个运算符,配套使用. new:用于分配内存,与C语言中的 malloc 相同,分配在堆内存 delete:用于释放内存,与C语言中的 free 相同,释放堆 ...

  2. [BUAA软工]Alpha阶段事后分析

    设想和目标 虽然我们是从零开始的一个自定义项目,但语音Coding助手从一开始的设计与目标就很明确:加入语音接口使其能在shell端实现命令语音实现以及编辑运行脚本,设计前端编辑器并将后端shell与 ...

  3. 剑指offer:二叉搜索树与双向链表

    题目描述: 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向. 思路分析: 这道题一开始的思路是借用队列结构,首先中序遍历二叉树,按顺序 ...

  4. 安装比特币区块链钱包API(Blockchain Wallet用户发送和接收比特币的简单API)

    区块链钱包API提供了一个简单的界面,商家可以用它以编程方式与钱包进行交互. 安装:要使用此API,您需要运行负责管理区块链钱包的小型本地服务. 您的应用程序通过HTTP API调用在本地与此服务进行 ...

  5. visual studio 无添加视图 选项

    我是因为 UserController未继承 Controller

  6. 随便贴两个漏洞,如 Apache JServ协议服务

    1.Apache JServ协议服务 描述:Apache JServ协议(AJP)是一种二进制协议,可以将来自Web服务器的入站请求代理到 位于Web服务器后面的应用程序服务器.不建议在互联网上公开使 ...

  7. Nginx 必须知道哪些事?

    Nginx(发音同engine x)是一个异步框架的 Web 服务器,也可以用作反向代理,负载平衡器 和 HTTP 缓存.该软件由 Igor Sysoev 创建,并于2004年首次公开发布.同名公司成 ...

  8. 【非lodop的】JS和html相关博文索引

    JS: eval()方法:JS-JAVASCRIPT的eval()方法. Date()对象.getFullYear() 方法.getDate()方法.console.dir()方法:LODOP打印用J ...

  9. [神经网络与深度学习][计算机视觉]SSD编译时遇到了json_parser_read.hpp:257:264: error: ‘type name’ declared as function ret

    运行make之后出现如下错误: /usr/include/boost/property_tree/detail/json_parser_read.hpp:257:264: error: 'type n ...

  10. 在使用FPGA来控制DDR3/DDR2 IP 的时候两个错误的解决办法

    对于熟悉Intel FPGA的老(gong)司(cheng)机(shi)来说,外部存储器的控制早已是轻车熟路,但是对于新手,DDR3/DDR2 的IP使用也许并没有那么简单,不过没关系,骏龙的培训网站 ...