首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >AJAX--总结

AJAX--总结

作者头像
思索
发布2024-08-16 09:31:21
发布2024-08-16 09:31:21
40900
代码可运行
举报
运行总次数:0
代码可运行

AJAX

2018-9-6 14:42:53

AJAX简介

​ HTTP协议------>HTTP权威指南

​ 请求:客户端去向服务端请求一个文件

​ 响应:服务端把对应的文件内容返回给客户端,一般服务端有输出才算真正的响应.

​ 传统请求:地址栏刷新请求

​ AJAX:通过技术偷偷请求

创建对象

​ new XMLHttpRequest();

属性
readyState

HTTP 请求的状态.当一个 XMLHttpRequest 初次创建时,这个属性的值从 0 开始,直到接收到完整的 HTTP 响应,这个值增加到 4。

状态

名称

描述

0

Uninitialized

初始化状态。XMLHttpRequest 对象已创建或已被 abort() 方法重置。

1

Open

open() 方法已调用,但是 send() 方法未调用。请求还没有被发送。

2

Sent

Send() 方法已调用,HTTP 请求已发送到 Web 服务器。未接收到响应。

3

Receiving

所有响应头部都已经接收到。响应体开始接收但未完成。

4

Loaded

HTTP 响应已经完全接收。

readyState 的值不会递减,除非当一个请求在处理过程中的时候调用了 abort() 或 open() 方法。每次这个属性的值增加的时候,都会触发 onreadystatechange 事件句柄。

responseText

服务器接收到的响应体(不包括头部),如果还没有接收到数据的话,就是空字符串。

status

由服务器返回的 HTTP 状态代码,如 200 表示成功。

事件句柄
onreadystatechange

每次 readyState 属性改变的时候调用的事件句柄函数。当 readyState 为 3 时,它也可能调用多次。

方法
open()

初始化 HTTP 请求参数,例如 URL 和 HTTP 方法,但是不发送请求。

代码语言:javascript
代码运行次数:0
运行
复制
open(method, url, async, username, password)

method 参数是用于请求的 HTTP 方法。值包括 GET、POST 和 HEAD。

url 参数是请求地址。

async 参数指示请求使用应该异步地执行。如果这个参数是 false,请求是同步的,后续对 send() 的调用将阻塞,直到响应完全接收。如果这个参数是 true(默认),请求是异步的,且通常需要一个 onreadystatechange 事件句柄。username 和 password 参数是可选的,为 url 所需的授权提供认证资格。如果指定了,它们会覆盖 url 自己指定的任何资格。

send()

发送 HTTP 请求,get方法无参,post方式有可选参。

setRequestHeader()

向一个打开但未发送的请求设置或添加一个 HTTP 请求。

AJAX+PHP流程
  1. 创建对象
  2. 请求初始化
    1. 发送请求
      1. 接受并处理结果
GET传参

可以直接拼接传参

POST传参

setRequestHeader() 设置Post传参

方法原理:

​ 模拟表单

HTML表单enctype值介绍

描述

application/x-www-form-urlencoded

在发送前编码所有字符(默认)

multipart/form-data

不对字符编码。 在使用包含文件上传控件的表单时,必须使用该值。

text/plain

空格转换为 "+" 加号,但不对特殊字符编码。

放在send之前,open之后

setRequestHeader('','application/x-www-form-urlencoded')

send('a'+n1+'a2'+n2)

数组处理
php后端:

​ encho json_encode() ---------->将PHP数据转为JSON

前端:

​ eval() 计算 JavaScript 字符串,并把它作为脚本代码来执行。

​ 1.eval('var yy = ' + jsonstr )

​ 2.var yy = eval('({json字符串})')

​ JSON解析器只解析json

​ JSON.parse()

同步异步

​ open()方法的参3,用于控制是否同/异步 默认参数为true,表示请求是异步的,AJAX不会影响到其他程序的执行. 参数为false,表示请求是同步的. AJAX将阻塞之后的程序运行,直到响应完全接收完毕为止.

AJAX无法跨域与jsonp

​ AJAX无法跨域 JSONP利用到script标签 不受同源策略的影响.所以可以跨域

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-09-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • AJAX
    • AJAX简介
    • 创建对象
    • 属性
      • readyState
      • responseText
      • status
    • 事件句柄
      • onreadystatechange
    • 方法
      • open()
      • send()
      • setRequestHeader()
    • AJAX+PHP流程
    • GET传参
    • POST传参
    • 数组处理
    • 同步异步
    • AJAX无法跨域与jsonp
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档