目录

  • Ajax
    • 1. 原生 JS 实现 Ajax
    • 2. 使用 Ajax 实现异步通信
      • a. Ajax 的基础语法
      • b. 用 Ajax 传递数据
        • i. 传递字符串数据
        • ii. 传递 JSON 数据
    • 3. 异步通信案例:搜索候选栏
      • a. 主要功能
      • b. 代码实现
      • c. 示例文档与效果图

Ajax

Ajax(Asynchronous Javascript And XML,异步 JavaScript 和 XML):一种创建交互式、快速动态网页应用的网页开发技术,无需重新加载整个网页的情况下,能够更新部分网页的技术。通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
Ajax 可以请求并获取服务器的数据,来完成与服务的通信。例如,当向搜索引擎的输入框中输入字符时,Ajax 把输入的字符发送给了服务器,服务器返回搜索候选项;当输入用户名时,页面通过 Ajax 把用户名发送给服务器,服务器返回用户是否重复的检验结果。
1. 原生 JS 实现 Ajax
使用原生 JS 实现 Ajax 的异步通信功能:

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>原生js实现ajax异步通信</title>
</head>
<body>
<!--
js原生ajax实现原理
XMLHttpRequest 一个可以向服务器发送数据,并能接受返回数据的js对象. 常用方法和属性
open(method,url,boolean async):创建打开一个连接 参数method请求方式 url服务器地址 async是否异步
send():开始发送数据
readyState:请求就绪状态 值为4时说明请求准备完成
onreadystatechange:监听请求就绪状态的改变
status:请求完成情况 值为200时说明请求成功完成
responseText:服务器返回的文本 查询手册完成功能:
点击图片时,请求服务器获取数据,把接收的数据显示在页面 -->
<img src="../img/timing.gif" onclick="doAjax()">
<p id="describe">GIF</p>
<script type="text/javascript">
let http = new XMLHttpRequest();//一个可以向服务器发送数据并接收服务器返回数据的对象
let result = null;//服务器返回的数据
http.onreadystatechange = function(){//请求就绪状态改变时
// console.log(http.readyState);//请求就绪状态
if(http.readyState == && http.status == ){//请求成为完成
let res = http.responseText;//服务器返回的文本数据
result = res;//服务器返回的数据
console.log("res="+res);
}
}; //点击图片时,请求服务器获取数据,把接收的数据显示在页面
function doAjax(){
//发送ajax请求
http.open("get","../data/info.txt",true);//创建打开一个异步请求
// http.open("get","../data/info.txt",false);//创建打开一个同步请求
http.send();//开始发送数据 //其它业务代码
console.log("其它业务代码 result="+result);//发送ajax之后的其它js业务代码
//同步 发送ajax请求之后其它js业务代码必须等待ajax请求成功以后才能执行
//异步 发送ajax请求之后的其它js业务代码的执行,与ajax请求的执行,没有任何关系.
//总结: ajax异步请求时服务器返回的数据只能在ajax请求完成的回调函数中使用.
} </script>
</body>
</html>

2. 使用 Ajax 实现异步通信
JS 是一门前端语言。
Ajax 是一门技术,它提供了异步更新的机制,使用客户端与服务器间交换数据而非整个页面文档,实现页面的局部更新。
jQuery 是一个框架,它对 JS 进行了封装,使其更方便使用。jQuery 使得 JS 与 Ajax 的使用更方便。这里使用的是 jQuery 的 Ajax 插件。
a. Ajax 的基础语法

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>jquery的Ajax基础语法</title>
</head>
<body>
<!--
jquery ajax语法:
$.ajax(配置); 配置是个JSON对象 常用属性有
type 请求方式 get post
url 服务器地址
data 发送给服务器的数据 d
ataType 预期服务器将要返回的数据类型 text json
async 是否异步 默认true异步
success 请求成功时的回调函数
error 请求失败时的回调函数 使用示例:
//发送ajax请求
$.ajax({
type:"get",
url:"../data/student.txt",
data:{name:"张三",pass:},
dataType:"text",
async:true,
success:function(response){},
error:function(error){}
}); 简写形式:
语法: $.get(url,data,success); 使用示例:
$.get("test.php", { name: "张三", pass: "" },
function(response){
console.log(response);
}); 语法: $.post(url,data,success); 使用示例:
$.post("test.php", { name: "张三", pass: "" },
function(response){
console.log(response);
}); -->
</body>
</html>

b. 用 Ajax 传递数据

  • student.txt
{
"id":,
"name":"刘一",
"age":,
"addr":"广州市",
"desc":"跑步"
}
JSON 的格式规定,文档里的 JSON 因为是字符串格式所以属性和内容都要加双引号。如果返回的是 JSON 数组,那就是 [{},{},..]

i. 传递字符串数据

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>jQuery的ajax传递数据</title>
<!--引入Jquery库文件-->
<script src="../js/jquery-1.11.3.js"> </script>
</head>
<body>
<!--
jQuery的ajax示例
.点击图片请求服务器(用本地json文件模拟服务器),并把接受到的数据显示在页面 -->
<img src="../img/timing.gif" onclick="doAjax()">
<p id="describe">GIF</p>
<script type="text/javascript">
//1.点击图片请求服务器(用本地文件模拟服务器),并把接受到的数据显示在页面
function doAjax(){ let result = null;//服务器返回的数据 //发送ajax请求
$.ajax({
type:"get", //本地文件只能使用get方式
url:"../data/student.txt",//服务器地址
//dataType:"json",//预期服务器返回json,走一次JSON.parse()
success:function(response){//成功回调
console.log(response);
let resObj = JSON.parse(response);//把服务器返回的字符串转为对象
console.log("resObj.desc="+resObj.desc);//描述信息
result =resObj.desc;//把服务器返回的字符串
$("#describe").text(resObj.desc);//把服务器返回的数据显示在页面
},
error:function(error){//失败回调
console.log(error);
}
}); //其它业务代码
console.log("其它业务代码 result="+result);//发送ajax之后的其它js业务代码
//同步:发送ajax请求之后其它js业务代码必须等待ajax请求成功以后才能执行
//异步:发送ajax请求之后的其它js业务代码的执行,与ajax请求的执行,没有任何关系
//总结:ajax异步请求时服务器返回的数据只能在ajax请求完成的回调函数中使用
} </script>
</body>
</html>

ii. 传递 JSON 数据

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>jQuery的ajax传递数据</title>
<!--引入Jquery库文件-->
<script src="../js/jquery-1.11.3.js"> </script>
</head>
<body>
<!--
jQuery的ajax示例
.点击图片请求服务器(用本地json文件模拟服务器),并把接受到的数据显示在页面 -->
<img src="../img/timing.gif" onclick="doAjax()">
<p id="describe">GIF</p>
<script type="text/javascript">
//1.点击图片请求服务器(用本地文件模拟服务器),并把接受到的数据显示在页面
function doAjax(){ let result = null;//服务器返回的数据 //发送ajax请求
$.ajax({
type:"get", //本地文件只能使用get方式
url:"../data/student.txt",//服务器地址
dataType:"json",//加了dataType, 回调传递的就是直接可以操作的json对象
success:function(response){//成功回调
console.log(response);
console.log("resObj.desc="+response.desc);//描述信息
result =response.desc;//把服务器返回的字符串
$("#describe").text(result);//把服务器返回的数据显示在页面
},
error:function(error){//失败回调
console.log(error);
}
}); //其它业务代码
console.log("其它业务代码 result="+result);//发送ajax之后的其它js业务代码
//同步:发送ajax请求之后其它js业务代码必须等待ajax请求成功以后才能执行
//异步:发送ajax请求之后的其它js业务代码的执行,与ajax请求的执行,没有任何关系
//总结:ajax异步请求时服务器返回的数据只能在ajax请求完成的回调函数中使用
} </script>
</body>
</html>

3. 异步通信案例:搜索候选栏

a. 主要功能

  1. 使用本地文件模拟服务器;
  2. 实现百度的搜索候选功能。

b. 代码实现

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>搜索候选栏</title>
<!--引入Jquery库文件-->
<script src="../js/jquery-1.11.3.js"></script>
<style type="text/css">
.content {
width: 643px;
margin: 200px auto;
text-align: center;
} input[type='text'] {
width: 534px;
height: 40px;
font-size: 14px;
} input[type='button'] {
width: 100px;
height: 46px;
background: #38f;
border: ;
color: #fff;
font-size: 15px
} .show {
position: absolute;
width: 516px;
border: 1px solid #efefef;
border-top: ;
display: none;
text-align: left;
color: darkgray;
line-height: 20px;
padding: 5px 10px;
}
</style>
<script type="text/javascript">
//当键盘按键弹起时调用
function searchWord(obj) {
console.log(obj.value);//当前输入内容
if(obj.value.length == )
return;//没有输入内容时不显示搜索候选 $("#show").empty();//每次添加搜索候选项之前,先把以前的候选项清除 let reg = new RegExp("^"+obj.value);//匹配以当前输入内容开头的字符 //把用户输入的字符发送给服务器
$.ajax({
type:"get",//请求方式
url:"../data/data.txt",//模拟服务器地址
data:{"msg":obj.value},//发送给服务器的数据
success:function(response){
console.log("response=" + response);
console.log(typeof response);//string
let arr = JSON.parse(response);//把string字符串转为object对象(数组)
for(let s of arr){//迭代候选项
if(reg.test(s)){//是否是以输入字符开头
$("#show").append("<div>"+s+"</div>");//追加搜索候选项
}
} // $("#show").css("display","block");//显示div
$("#show").show();//同上
// $("#show").hide();//隐藏
},
error:function(error){
console.log(error);//失败信息
}
});
}
</script>
</head>
<body>
<div class="content"><input type="text" name="word" onkeyup="searchWord(this)"><input type="button" value="搜索一下">
<div class="show" id="show"></div>
</div>
</body>
</html>

c. 示例文档与效果图

  • data.txt
[
"id:qwert",
"name:Regino",
"name:Reggie",
"age:23",
"addr:Guangdong",
"blog:https://blog.csdn.net/Regino"
]

因为接受的是数组形式,所以这里是 JSON 的数组类型。

												

Ajax 简述与基础语法的更多相关文章

  1. ajax基础语法、ajax做登录、ajax做用户名验证是否可用、ajax做关键字查询动态显示、ajax做用表格显示数据并增加操作列

    AJAX: AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新.   ...

  2. 从零开始学 Web 之 Ajax(二)PHP基础语法

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  3. ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段

    ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...

  4. Ajax基础知识 浅析(含php基础语法知识)

    1.php基础语法    后缀名为.php的文件 (1) echo   向页面中输入字符串  <?php    所有php相关代码都要写在<?php ?>这个标签之中 echo &q ...

  5. python基础语法、数据结构、字符编码、文件处理 练习题

    考试范围 '''1.python入门:编程语言相关概念2.python基础语法:变量.运算符.流程控制3.数据结构:数字.字符串.列表.元组.字典.集合4.字符编码5.文件处理''' 考试内容 1.简 ...

  6. jQuery 基础语法

    jQuery介绍 1.jQuery是一个轻量级的.兼容多浏览器的JavaScript库. 2.jQuery使用户能够更方便地处理HTML Document.Events.实现动画效果.方便地进行Aja ...

  7. <学习笔记 之 JQuery 基础语法>

    jQuery 库 - 特性 jQuery 是一个 JavaScript 函数库. jQuery 库包含以下特性: HTML 元素选取 HTML 元素操作 CSS 操作 HTML 事件函数 JavaSc ...

  8. 简明易懂,将细节隐藏,面向新手树立web开发概念——学完Java基础语法,超快速上手springboot+mybatiJavaWeb开发

    简明易懂,将细节隐藏,面向新手树立web开发概念 --学完Java基础语法,超快速上手JavaWeb开发 Web本质(先忽视各种协议) Web应用可以理解为浏览器和服务器之间的交互. 我们可以看一个简 ...

  9. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

随机推荐

  1. hdu2087kmp模板练习

    题目网址:http://icpc.njust.edu.cn/Problem/Hdu/2087/ 代码: #include<bits/stdc++.h> using namespace st ...

  2. ubuntu在github上传项目

    GitHub是一个面向开源及私有软件项目的托管平台,因为只支持git 作为唯一的版本库格式进行托管,故名GitHub. 作为开源代码库以及版本控制系统,Github拥有超过900万开发者用户.随着越来 ...

  3. TPYBoard v202开发板通过I2C协议驱动oled

    最近无聊的时候研究了一下TPYBoard v202开发板,发现网上TPYBoard开发驱动oled的这块资料比较少,本人测试成功后给大家分享一下经验 下面通过代码讲解一下 1.首先需要导包, 在网上下 ...

  4. Redis学习笔记2-redis管道(pipeline)

    redis的管道(Pipelining)操作是一种异步的访问模式,一次发送多个指令,不同步等待其返回结果.这样可以取得非常好的执行效率.这就是管道,调用方法如下: 来源:http://blog.csd ...

  5. Python第六章-函数02-函数的作用域

    函数 三.作用域规则 有了函数之后,我们必须要面对一个作用域的问题. 比如:你现在访问一个变量,那么 python 解析器是怎么查找到这个变量,并读取到这个变量的值的呢? 依靠的就是作用域规则! 3. ...

  6. TensorFlow 卷积神经网络手写数字识别数据集介绍

    欢迎大家关注我们的网站和系列教程:http://www.tensorflownews.com/,学习更多的机器学习.深度学习的知识! 手写数字识别 接下来将会以 MNIST 数据集为例,使用卷积层和池 ...

  7. 骑士cms-通读全文-代码审计

    版本号:3.5.1 下载地址:http://103.45.101.75:66/2/201412/74cms.rar 1.审计方法 通读审计 1.1查看文件结构 首先需要看看有哪些文件和文件夹,寻找名称 ...

  8. ArcSDE数据库、文件地理数据库和个人地理数据库的区别

    Geodatabase地理数据库分为: Personal Geodastabase个人地理数据库, File Geodatabase文件地理数据库, ArcSDE Geodatabase SDE地理数 ...

  9. centos7环境下安装nginx

    安装所需环境 nginx是C语言开发,在Linux和windows环境上面都可以运行. 1.gcc安装 安装nginx需要将官网下载的代码进行编译,编译依赖gcc环境,如果没有gcc环境,需要先安装g ...

  10. MATLAB——文件读写(1)

    1.文件打开关闭 (1)文件打开 fid=fopen(文件名,‘打开方式’)说明:其中fid用于存储文件句柄值,如果返回的句柄值大于0,则说明文件打开成功.文件名用字符串形式,表示待打开的数据文件.常 ...