Ajax的用法

1 Ajax是什么

1.1 Asynchronous JavaScript and XML(异步的javascript和xml)

实质为:使用浏览器内置的一个对象(XmlHttpRequest)向服务器发送请求,服务器返回xml数据或文本数据给浏览器,然后在浏览器端,使用这些数据更新部分页面,在整个过程中,页面无任何刷新。

1.2 传统的等待—响应—等待

在传统的web应用中,比如注册,用户填写整个注册表单后提交,此时浏览器会将整个注册页面抛弃,等待服务器返回一个新的完整的页面。在等待过程中,用户不能够做其他操作。服务器生成新的页面发送给浏览器,浏览器需要重新解析这个页面生成相应的页面。

1.3 图示

① Ajax引擎(即XmlHttpRequest对象),首先为该对象注册一个监听器(该监听器是一个事件处理函数,对状态改变事件(readyStatechange)进行监听)

② 当用户对GUI做了某种操作(将产生对应的事件,如焦点失去事件等)

③ 一旦产生对应的事件,将触发事件处理代码

④ 在执行事件处理代码时,会调用Ajax引擎(XmlHttpRequest对象)

⑤ 发送请求:Ajax引擎被调用后,将独自向服务器发送请求(独立于浏览器之外)

  继续其他操作:在Ajax引擎发送请求的同时,用户在浏览器还可以对GUI继续做其他操作,该请求是异步请求(Ajax引擎发送请求时,没有打断用户的操作)

⑥ 服务器的web组件对请求进行处理

⑦ 服务器可能会调用到数据库或者处理业务逻辑的Java类

⑧ 服务器将处理结果响应给(只返回部分数据,可以是xml或者文本)Ajax引擎

⑨ 监听器通过Ajax引擎获取响应数据(xml或者文本)

⑩ 监听器对GUI中的数据进行更新(局部更新,不是整个页面刷新)

整个过程中大部分是通过JS实现的,响应数据可能是xml,所以Ajax可以看做是多种技术的融合。

 2 Ajax编程

第一步 获得XmlHttpRequest对象

该对象由浏览器提供,但是该类型并没有标准化。

ie和其他浏览器不同,其他浏览器都支持该类型,而ie不支持。

    function getXmlHttpRequest(){var xhr = null;if((typeof XMLHttpRequest) != 'undefined'){xhr = new XMLHttpRequest();}else{xhr = new ActiceXObject(Microsoft.XMLHttp);}return xhr;}

 第二步 使用XmlHttpRequest向服务器发请求

a. 发送get请求

function change(v1) {var xhr = getXmlHttpRequest();/*open(请求方式,请求地址,同步/异步)请求方式:get/post请求地址:如果是get请求,请求参数添加到地址之后比如 get_comments.do?name=QQ同步/异步:true表示异步*/xhr.open("get", encodeURI("get_comments.do?name=" + v1), true);/*注册一个监听器(即当xhr的状态发生改变产生了readystatechange事件,该事件会由一个函数f1来进行处理,这个函数里需要获得服务器返回的数据,然后更新页面)*/xhr.onreadystatechange = f1;/*只有调用send方法之后,请求才会真正发送*/xhr.send(null);}

 

b. 发送post请求

function change2(v1){var xhr = getXmlHttpRequest();xhr.open("post","get_comments.do",true);//必须添加一个消息头 content-typexhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");xhr.onreadystatechange = f1;xhr.send("name=" + v1);}

 

第三步  在服务器端处理请求

第四步 在监听器当中,处理服务器返回的响应

    xhr.onreadystatechange = f1;function f1(){if(xhr.readyState == 4){var txt = xhr.responseText;document.getElementById("d1").innerHTML = txt;}}

 或者

    xhr.onreadystatechange =function(){//编写相应的处理代码if(xhr.readyState == 4){//只有readyState等于4,xhr才完整地接收到了服务器返回的数据//获得文本数据var txt = xhr.responseText;//获得一个xml dom 对象var xml = xhr.responseXML;//dom操作 更新页面document.getElementById("d1").innerHTML = txt;}}                        

 

关于Ajax的其他应用,可以参考网盘文件。

(1)关于get请求中,ie浏览器的缓存功能,使得并非每一次触发事件都发起请求的问题的解决

(2)关于get请求和post请求中,包含中文时的编码问题解决等。

转载于:https://www.cnblogs.com/hnini/p/6065023.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/429850.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql降级_mysql8降级到mysql5的方法介绍

本篇文章给大家带来的内容是关于mysql8降级到mysql5的方法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。最近在研究liferay的使用。liferay可以连接mysql数据库。电脑中装的mysql的最新版本是mysql8。于是开始按照life…

Node.js server使用

一、创建项目 #创建项目目录 cd /data mkdir webroot cd webroot#初始化git git init vim .gitignore 输入: node_modules/ 保存: :wq#初始化npm,生成package.json npm init#安装express npm install -D express#创建入口文件 vim app.js输入: var expr…

ubuntu安装jdk_mysql_Ubuntu server 安装及jdk+mysql安装教程

Ubuntu server 安装教程1.查找及下载Ubuntu镜像文件可以在以下页面下载想要的版本,我这里选择19.04 server版的iso镜像文件:http://mirrors.163.com/ubuntu-releases/19.04/2.腾出一个空U盘,4G左右就行,iso文件本身就有750M左右,制作安装盘1).使用UltraI…

模仿Linux内核kfifo实现的循环缓存

想实现个循环缓冲区(Circular Buffer),搜了些资料多数是基于循环队列的实现方式。使用一个变量存放缓冲区中的数据长度或者空出来一个空间来判断缓冲区是否满了。偶然间看到分析Linux内核的循环缓冲队列kfifo的实现,确实极其巧妙。…

win32mysql数据库回复_windows mysql 数据库备份与还原方法

一.使用 Mysql 自带 mysqldump 命令进行数据库备份mysql 数据库自带备份命令 mysqldump ,可对数据库进行备份操作最简单的备份是将数据库备份至本地,生成 **.sql 文件编写备份脚本文件(创建一个 txt 文件,写入批处理脚本,再将文件的后缀改为…

领域模型(domain model)贫血模型(anaemic domain model)充血模型(rich domain model)

领域模型是领域内的概念类或现实世界中对象的可视化表示,又称为概念模型或分析对象模型,它专注于分析问题领域本身,发掘重要的业务领域概念,并建立业务领域概念之间的关系。 贫血模型是指使用的领域对象中只有setter和getter方法&…

datagrid显示mysql_WPF DataGrid显示MySQL查询信息,且可删除、修改、插入 (原发布 csdn 2018-10-13 20:07:28)...

1、入行好几年了,工作中使用数据库几率很小(传统行业)。借着十一假期回家机会,学习下数据库。2、初次了解数据库相关知识,如果本文有误,还望告知。3、本文主要目的,记录下wpf界面显示数据库信息,且可进行删…

网站SEO优化中内部链接的优化

重要性:内链有效的优化能够间接的提高某页面的权重达到搜索排名靠前的效果。同时有效的带领搜索引擎蜘蛛对整站进行抓取。 网站头部导航: 这个导航称为‘网站主导航’,当用户来到网站需要给他们看到的内容。也就是UE(用户体验&…

mysql 集群 qps_MySQL Cluster:如何通过扩展为MySQL带来2亿QPS

本篇文章的目的在于介绍MySQL Cluster——也就是MySQL的一套内存内、实时、可扩展且具备高可用性的版本。在解决标题中所提到的每秒2亿查询处理能力问题之前,我们先对MySQL集群的背景信息及其架构进行一番回顾,这将有助于大家理解上述目标的实现过程。My…

测试题的答案(技术博客)

根据老师的要求,我把上次测试的答案汇总了下,将程序写的得到满分的答案给挑了出来,希望大家不要追究版权问题,若有问题,我们私下武力解决问题。 第一题:从键盘输入一个大写字母,要求改用小写字母…

history模式监听_面试题:VueRouter中的 hash 模式和 history 模式有什么区别

面试题:VueRouter中的 hash 模式和 history 模式有什么区别hash模式hash 模式的路由中带有 # 号hash 模式通过 window.onhashchange 方法监听路由的修改hash 模式在页面刷新的时候,发送的请求 url 是不带 # 后面的内容的hash 模式可以兼容部分低版本的浏…

DC综合流程

Design Compiler and the Design Flow 步骤 将HDL描述的设计输入到Design Compiler中Design Compiler使用technology libraries, synthetic or DesignWare libraries, and symbol libraries执行综合过程,并展示综合结果。将HDL翻译为门级描述之后,Design…

hdu 2222 Keywords Search(ac自动机)

题目链接 http://acm.hdu.edu.cn/showproblem.php?pid2222 题意:给你一系列子串,再给你一个主串问你主串一共有几个匹配子串 原来使用字典树写的但数据有点大TLE了,然后就开始学习ac自动机了,ac自动机就像是多串匹配的kmp原理也是…

对象必须实现 iconvertible。_精雕基础教程:对象的显示颜色

“颜色工具栏”用于修改图形、文字等操作对象的颜色,设置轮廓线或者区域填充颜色,从而获得彩色效果图。这一篇文章我们叙述如何修改对象的显示颜色和填充颜色。如下图所示,颜色工具栏按钮功能的说明参见相关部分。图 - 颜色工具栏修改对象颜色…

抓包mysql乱码_抓包数据乱码是什么情况?

为什么会出现这种情况?细心的童鞋可能发现是我们发送给服务器的请求连接的数据不同:第一张图的信息是{"roomid":98284,"uid":271298361556770}第二张图的信息是{"uid":276194535568357,"protover":2,"room…

WebView

WebView在Android系统中内置了一款高性能webkit内核浏览器,在SDK中封装为一个叫做WebView组件,WebView是基于webkit引擎,展现Web页面的控件。 WebView控件功能强大,除了具有一般View的属性和设置外,还可以对url请求、页…

mysql sql优化器_MySQL SQL优化之‘%’

设计索引的主要目的就是帮助我们快速获取查询结果,而以%开头的like查询则不能够使用B-Tree索引。考虑到innodb的表都是聚簇表(类似于oracle中的索引组织表),且二级索引叶节点中记录的结构为(索引字段->主键字段),我们可以通过改写sql(mysq…

[转载]析构函数的虚析构和非虚析构调用的差别

代码示例: 非虚析构的情况下. #include <stdio.h> #include <iostream>using namespace std;class A { public:A(){std::cout << "A is created." << std::endl;}~A(){std::cout << "A is deleted." << std::endl;} }…

外部函数能修改闭包内的变量_Python函数式编程,Python闭包

前置内容为了更容易理解闭包&#xff0c;在说闭包之前&#xff0c;讲一下两个概念&#xff1a;作用域和嵌套函数。作用域作用域是变量能被访问的范围&#xff0c;定义在函数内的变量是局部变量&#xff0c;局部变量的作用范围只能在函数内部&#xff0c;它不能在函数被外引用。…

onmousedown活用之碰撞效果

通过绝对定位,在页面中随意位置设置两个div; 也就是说div 是拖动的框,div1和div2是被触碰的框; 1 <!DOCTYPE html>2 <html>3 4 <head>5 <meta charset"UTF-8">6 <title></title>7 <style type"text/css&quo…