离职中,有招人的求推荐一下,评论或者私信我邮箱和公司,我发简历给您,最近一直在搞基础的东西,弄了一个持续更新的github笔记,可以去看看,诚意之作(本来就是写给自己看的……)链接地址:Front-End-Basics

此篇文章的地址:Ajax基础相关

基础笔记的github地址:https://github.com/qiqihaobenben/Front-End-Basics,可以watch,也可以star。

正文开始……

Ajax

Asynchronous JavaScript and XML : 异步的js和XML,前后端数据交互的一种技术。

Ajax优点

传输获取数据,不用跳转页面,在本页面请求服务器,做到实时验证。
减少用户返工率并且优化用户体验。

方式

GET方式

把数据放在url中发送,以获取数据为主

步骤

1、创建一个ajax对象

var ajax = new XMLHttpRequest();

2、传入请求参数

//method,url,true    参数
ajax.open('get','PHP/get.PHP?user='+encodeURIComponent(value),true);

3、发送数据

ajax.send(null);

send()方法传入一个参数,即要作为请求主体发送的数据。如果不需要通过请求主体发送数据,则必须传入null,因为这个参数对有些浏览器来说是必需的。

注意点

1、用get方式请求,是有长度限制的。因为是通过地址栏的查询信息来请求的。(即get通过URL地址传输,post通过浏览器内部传输)

2、请求信息在地址栏中显示,直接暴露了用户填写的信息,并且访问的数据会被浏览器缓存到历史记录中,所以说不安全。

3、在get拼接数据的时候要用encodeURIComponent来包一下,不然在IE低版本浏览器中使用中文会乱码的。

encodeURIComponent('刘')  转成url
decodeURIComponent('%E5%88%98')  转成中文

4、有缓存问题 解决方法:在url?后面连接一个随机数,时间戳

POST方式

数据放在 send() 中发送

步骤

1、创建一个ajax对象

var ajax = new XMLHttpRequest();

2、传入请求参数

ajax.open('post','PHP/post.PHP',true);
//method,true三个参数的含义
1、提交方式 Form-method 
2、提交地址 Form-action 
3、异步(同步)
异步:非阻塞 前面的代码不会影响后面代码的执行
同步:阻塞 前面的代码会影响后面代码的执行

3、设置请求头

ajax.setRequestHeader('Content-Type','application/x-www-form-urlencoded')

// 要成功的发送请求头部信息,必须在调用open() 方法之后且调用send()方法之前调用setRequestHeader()

4、发送数据

ajax.send('user=cfangxu')

注意点

  1. 用post方式请求,理论上来说是没有长度或体积限制的,看具体浏览器和后端的设置。
  2. 数据是通过http正文(请求体-请求正文)进行发送的,不会直接的暴露用户的信息,并且发送的数据不会被浏览器缓存,相对来说是比较安全的。
  3. 在send()的前面需要设置一个请求头(不设置要出错)。
post提交的数据格式有多种

    text/plain
    application/x-www-form-urlencoded - 默认
    multipart/form-data

在post提交数据的时候,需要设置请求头content-type:值可以为上面三中类型之一

ajax.setRequestHeader( 'Content-Type','application/x-www-form-urlencoded');
  1. open的时候,不用像get那样去拼数据,拼接数据是在send中填写。

接收数据

onload 事件

属于html5的,有兼容性问题

ajax.onload = function () {
    //打印传输过来的数据
    console.log(ajax.responseText)
}

onreadystatechange 事件

支持IE6,兼容性好。

其中的readyState属性:请求状态 
0  (未初始化)还没有调用open()方法0是监听不到的
1  启动,open()方法已经被调用。
2  发送,send() 方法已经被调用,但尚未接收到响应。 
3  接收,已经接收到部分相应数据。 
4  完成,已经接收到全部响应数据,而且可以在客户端使用了。

readyState : ajax工作状态
onreadystatechange : 当readyState改变的时候触发
status : 服务器状态,http状态码
responseText : 返回以文本形式存放的内容 ajax请求返回的内容就被存放到这个属性下面

注意

  • 事件监听最好写在事件发生之前(即.onload(.onreadystatechange)要放在.send之前),避免没有监听到。

扩展

XMLHttpRequest 兼容性问题,单纯了解,可以直接略过

new XMLHttpRequest() ie6 及以下不支持,所以需要用到插件
new ActiveXObject('MSXML2.XMLHTTP')
IE中会有三种不同的XHR版本: MSXML2.XMLHTTPMSXML2.XMLHTTP.3.0MSXML2.XMLHTTP.6.0 因为只做了解,这里用最老的那一版

兼容写法如下:
var xhr = null;
if (window.XMLHttpRequest) {    
   //直接用XMLHttpRequest是不能做判断的,因为IE6下没有,window.XMLHttpRequest会返回undefined
   xhr = new XMLHttpRequest();
} else {
   xhr = new ActiveXObject('MSXML2.XMLHTTP');
}

也可以用try catch来解决。
try {
   xhr = new XMLHttpRequest();
} catch (e) {
   xhr = new ActiveXObject('MSXML2.XMLHTTP');
}

表单提交

form 标签的一些属性

action : 数据提交的地址,默认是当前页面

method : 数据提交的方式,默认是get方式
    1.get
    把数据名称和数据值用=连接,如果有多个的话,那么他会把多个数据组合用&进行连接,然后把数据放到url?后面传到指定页面
    2.post
    通过请求头进行请求

enctype : 提交的数据格式,默认application/x-www-form-urlencoded

上传文件

不管是form还是ajax,上传必须要用post请求方式来传输。如果后端返回的内容有中文编码格式,那么直接输入到页面中就能变成中文了。

form

<form action="post_file.PHP" method="post" enctype="multipart/form-data">
           <input type="file" name="file" id="f" value="" />
           <input type="submit" value="上传"/>
</form>
action会跳转页面

ajax

var ajax = new XMLHttpRequest();

ajax.open('post','post_file.PHP',true);

//传输类型设置为二进制的格式
ajax.setRequestHeader('Content-Type','multipart/form-data');

//二进制传输在写入send前要用FormData转换
var fromD = new FormData();    

//FormData构造函数中有一个append方法
//在file中,有一个对象:files(详细信息的列表)files[0]里面是files的具体参数;
fromD.append('file',f.files[0]);    

ajax.send(fromD)


ajax的上传方式需要注意以下几点:
1.new FormData()

2.给这个对象append(key,value)
key:跟后端的要求走
value:file元素的files[0];

3.send(这个对象)

XMLHttpRequest 2级

FormData

上面的ajax上传文件用到的 FormData 类型就是 XMLHttpRequest 2级中定义的。

FormData 为序列化表单以及创建与表单格式相同的数据(用于XHR传输)提供了便利。

var data = new FormData();
data.append('name','cfangxu');

append()方法接收两个参数:键和值,分别对应表单字段的名字和字段中包含的值。可以像上面代码一样添加任意多个值。

FormData 构造函数可以直接传入表单元素,表单元素的数据预先向其中填入键值对。

var data = new FormData(document.forms[0]);

FormData的另一个方便之处在于用其发送POST请求可以不必明确地在XHR对象上设置请求头部,XHR对象能够识别传入的数据类型是FormData的实例,并配置适当的头部信息。

overrideMimeType() 方法

重写XHR响应的MIME类型,比如服务器返回的MIME类型是 text/plain,但是数据中实际包含的是XML。根据MIME类型,即使数据是XML, responseXML属性中仍然是null,通过调用 overrideMimeType()方法,可以保证把响应当做XML而并非文本来处理。

var xhr = new XMLHttpRequest();
xhr.open('get','text.PHP',true);
xhr.overrideMimeType('text/xml');
xhr.send(null);

load 事件

上面提到过,用load事件替代readystatechange,响应接收完毕后会触发load事件,所以也就没有必要去检查readyState属性了,不过只要浏览器接收到服务器的响应,不管状态如何,都会触发load事件。所以必须要检查status属性,才能确定数据是否真的是可用的。

var xhr = new XMLHttpRequest();
xhr.onload = function () {
    if(xhr.status >= 200 && xhr.status < 300) {
        console.log(xhr.responseText);
    }else {
        console.log('Request is unsuccessful' + xhr.status)
    }
}
xhr.open('get','test.PHP',true);
xhr.send(null);

progress 事件

这个事件会在浏览器接收新数据期间周期性地触发。事件监听函数会接收到一个event对象,其target属性是XHR对象,但是包含着三个额外的属性:lengthComputable、position和totalSize。

  • lengthComputable: 是一个表示进度信息是否可用的布尔值。
  • position: 表示已经接收的字节数
  • totalSize: 表示根据Content-Length响应头部确定的预期字节数。

这些信息可以用来展示进度。

var xhr = new XMLHttpRequest();
xhr.onload = function () {
    if(xhr.status >= 200 && xhr.status < 300) {
        console.log(xhr.responseText);
    }else {
        console.log('Request is unsuccessful' + xhr.status)
    }
}
xhr.onprogress = function (event) {
    var showEle = document.getElementById('status');
    if(event.lengthComputable){
        showEle.innerHTML = '接收' + event.position + 'of' + event.totalSize + '字节';
    }
}
xhr.open('get',true);
xhr.send(null);

为确保正常执行,必须在调用open()方法之前添加onprogress事件监听函数。

总结

XMLHttpRequest实例的属性

readyState
responseType
responseText
responseXML
status
statusText
withCredentials

XMLHttpRequest实例的方法

abort() abort方法用来终止已经发出的HTTP请求。
getAllResponseHeaders()
getResponseHeader()
open()
send()
setRequestHeader()
overrideMimeType()

XMLHttpRequest实例的事件

readyStateChange事件 progress事件 load事件

条理清晰的Ajax基础讲解的更多相关文章

  1. ios – 将视频分享到Facebook

    我正在编写一个简单的测试应用程序,用于将视频从iOS上传到Facebook.由于FacebookSDK的所有文档都在Objective-C中,因此我发现很难在线找到有关如何使用Swift执行此操作的示例/教程.到目前为止我有这个在我的UI上放置一个共享按钮,但它看起来已禁用,从我读到的这是因为没有内容设置,但我看不出这是怎么可能的.我的getVideoURL()函数返回一个NSURL,它肯定包含视

  2. ios – 错误域= NSURLErrorDomain代码= -1003“找不到具有指定主机名的服务器

    当我尝试在设备上运行应用程序时出现此错误.当我在模拟器上运行它并且post请求正常工作时,我没有收到此错误.这是我的代码片段:任何帮助表示赞赏.谢谢解决方法此错误通常会提示DNS相关问题.检查设备上的DNS设置并确认您可以使用Safari或其他浏览器浏览互联网.如果有一个url,你可以在同一台服务器上获取,尝试直接在设备上的Safari中访问它.

  3. ios – Xcode Bot:如何在post触发器脚本上获得.ipa路径?

    我正在使用机器人来存档iOS应用程序,我需要获取.ipa产品路径才能将其发布到我们的分发系统中.机器人设置:并使用脚本打印所有env变量,其中不包含ipa文件的路径.此外,一些变量指向不存在的目录,即:XCS_OUTPUT_DIR这里的env变量输出:除此之外,我还能够确认.ipa文件是在另一个文件夹中创建的(/IntegrationAssets//

  4. ios – 使用CocoaPods post install hook将自定义路径添加到HEADER_SEARCH_PATHS

    解决方法在Podfile中定义一个方法:然后在post_install中调用该方法:

  5. iOS7 Safari中的全屏模式

    我正在使用SenchaTouch开发移动网站.在iOS7Safari中,我无法创建顶级地址栏和下面的工具栏消失了.Sencha过去常常处理iOS6,但iOS7最近的一些变化导致了这个问题.http://java.dzone.com/articles/safari-ios-7-and-html5我阅读了上面的链接&对于HTML5游戏而言,这似乎也是一个问题.一些其他应用程序.适用于iOS6的旧win

  6. ios – 如何使用新的Apple Swift语言发布JSON

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  7. ios – POST请求使用application / x-www-form-urlencoded

    后端开发人员在POST请求中给出了这些说明:>路线:{url}/{app_name/{controller}/{action}控制器和动作应该是小帽子.>API测试链接:http:****************>请求应该使用POST方法.>参数应通过请求内容体(FormUrlEncodedContent)传递.>参数应该是json格式.>参数是关键的.在协议中没有经验5,我搜索并结束了我的代码.

  8. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  9. ios – 在HTTPBody中设置NSDictionary并使用POST方法发送

    我想用POST方法调用Web服务.我需要发布一个带有URL的字典.我的Web服务参数如下:以下是我的要求:但是我收到以下错误:服务器拒绝此请求,因为请求实体的格式不受所请求方法所请求资源的支持解决方法请找到以下代码,将数据发布到Web服务.请注意这是我在我的一个申请中使用的样本.希望这可以帮助.从您的评论“服务器拒绝此请求”服务器是否支持JSON或XML格式.

  10. ios – 如何使用Firebase存储喜欢的内容

    我有一个关于firebase的后端,有像Facebook这样的帖子.所以我需要喜欢这些帖子的功能.问题是如何存储喜欢帖子的喜欢和用户?

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部