天天看点

AJAX5步法

AJAX5步法

1、创建异步对象XMLHttpRequest

AJAX5步法

2、设置回调函数

AJAX5步法

3、open()方法连接服务器

AJAX5步法

4.send()方法发送数据至服务器

AJAX5步法

5、回调函数中针对不同响应状态进行处理,局部更新界面

AJAX5步法

完整代码如下所示

AJAX5步法

接下来测试下get请求类型,将open连接服务器步骤里的请求类型设置为get,如下所示

AJAX5步法

利用HBuilder编辑器打开(启动时自带本地服务器)如下所示

AJAX5步法

接下来转换JSON数据为普通JS对象型,如下所示

AJAX5步法

AJAX封装

目前为止,已经实现基本功能,但AJAX的调用还十分麻烦,步骤比较繁琐,在日常开发一般会将其进行封装,所以接下来封装下AJAX功能相关步骤函数,以后使用直接调用即可,同时大大提高了开发效率。

为了使用方便,接下来封装AJAX的get和post

封装:基本模板与传参

AJAX5步法

此时调用模板时,如下所示

AJAX5步法

封装1:建立异步对象

AJAX5步法

封装2:判断请求类型

AJAX5步法

封装2:判断请求类型

get请求类型传值方式是将数据拼接到路由后进行传值,所以接下来需要判断是否传值(对比post请求),回顾之前所讲

AJAX5步法

1、get请求类型传值方式是将数据拼接到路由后进行传值

AJAX5步法

2、post请求类型判断是否有传值,如果有则send发送至服务器,没有则不发

AJAX5步法

封装3:注册事件,针对不同状态进行响应,获取返回数据

AJAX5步法

开发中,也可以将响应,即注册事件步骤,直接移至第一步创建异步对象下,以便更好地监听到状态变化。

封装调用:

接下来外部传参调用下封装的AJAX函数

AJAX5步法

此时控制台测试,便可以输出打印JSON格式数据,所以如果想用JS进一步操作,需要进行反序列化解析即JSON.parse(),然后操作其对页面进行局部更新。

AJAX5步法

AJAX跨域

跨域简介:

AJAX跨域指的是JS在不同的域之间进行数据传输或通信。

跨域方案:

1、jsonp跨域(重点)----前端处理方法

2、cros跨域-----后台处理

常见跨域场景?

所谓的同源是指,域名、协议、端口均为相同。

http://www.nealyang.cn/index.html 调用 http://www.nealyang.cn/server.php 非跨域

http://www.nealyang.cn/index.html 调用 http://www.neal.cn/server.php 跨域,主域不同

http://abc.nealyang.cn/index.html 调用 http://abc.neal.cn/server.php 跨域,子域名不同

http://www.nealyang.cn:8080/index.html 调用 http://www.nealyang.cn/server.php 跨域,端口不同

https://www.nealyang.cn/index.html 调用 http://www.nealyang.cn/server.php 跨域,协议不同

localhost 调用 127.0.0.1 跨域

AJAX跨域-JSONP

JSONP跨域:

jsonp跨域原理:借助网页标签中src属性的跨域特性实现

src简介:src是source的缩写,资源的意思,在html中src表示资源地址,是js文件和图片文件的引入方式,经常引用外部资源,可以实现跨域访问,如下所示

AJAX5步法

接下来调用下百度搜索接口,如下所示

https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/?wd=&cb=

解析:

wd为搜索关键词,百度搜索功能发送请求类型为get,因为所搜的关键词可以在url中可见。这里先不用回调

AJAX5步法

将之前代码做下调整,将url改为百度搜索接口,如下所示

AJAX5步法

注意:

因为是get方式,所以关键词传值需要拼接到url里,即通过data传参,且参数为想要的关键词,然后之前封装好的AJAX会将其进行封装,也就是说最后send对应的接口url为经过封装的AJAX函数拼接后的地址

https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/?wd=海贼王

将之前代码做下调整,将url改为百度搜索接口,如下所示

AJAX5步法

接下来使用JSONP实现跨域,本质利用src属性的跨域请求资源特性,同理脚本标签也是通过src引入资源,所以可以进行封装处理,实现AJAX的跨域访问远程资源。

接下来做下测试,script标签引入接口文件,并在接口加入回调函数,然后在页面定义调用

AJAX5步法

测试结果如下

AJAX5步法

此时虽然有报错,但是已经没有报跨域错误,接下来将调用位置做下调整,先定义声明函数,然后再进行传值,如下所示

AJAX5步法

修改后测试结果如下

AJAX5步法

AJAX跨域-CROS

除了通过JSONP解决跨域外,常见的方法还包含CROS方法

【前言】

CROS需要在后台进行配置→允许所有域名访问

1、PHP后台仅仅需要添加一句代码即可 header(’ Access-Control-Allow-Origin : * '); 表示允许所有域名访问。

2、JAVA后台需要下载CROS包,然后进一步配置