JS实现Ajax异步刷新

用JS实现post和get两种方式异步刷新

1,Ajax是个啥玩意?

Ajax 即"Asynchronous JavaScript And XML", 指一种创建交互式,快速动态网页应用的网页开发技术,无需加载整个网页的情况下,能够更新部分网页的技术。

2,异步刷新?是个啥玩意?

用js里面的XMLHttpRequest对象来和servlet交互,来实现数据的交换,这里只讲js的实现方式。

3,为什么要有异步刷新

提交表单内容到jsp页面,再jsp转发重定向,这样会把整个页面都给查一遍,是整个页面哦。所以不让整个页面刷新,就用了ajax,让页面局部刷新。

4,用一个使用电话号码注册的小demo来解释
后台servlet

protected void service(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {// 设置编码req.setCharacterEncoding("utf-8");resp.setCharacterEncoding("utf-8");// 文本类型 resp.setContentType("text/html; charset=utf-8");String mobile = req.getParameter("mobile");System.out.println(mobile);PrintWriter out = resp.getWriter();if ("19999999999".equals(mobile)) {// 存在号码out.write("true");} elseout.write("false");out.close();}

get方式

前台页面

电话号码:<input type="text" id = "mobile"/> <br/><button onclick = "getRegister()">注册</button><script type="text/javascript">function getRegister() {// get 方式实现异步var mobile = document.getElementById("mobile").value;xmlHttp = new XMLHttpRequest();// 打开连接xmlHttp.open("get","jsServlet?mobile=" + mobile, true);// xmlHttp.setRequestHeader("", ""); get不用设置头信息// get发送null post 发送key = valuexmlHttp.send(null);xmlHttp.onreadystatechange = rollBack;}function rollBack() {// 服务器响应是否有此号码 true/falsevar result = xmlHttp.responseText;// status = 200 是服务器正常响应 readyState = 4是xmlhttp将响应信息全部读取完毕if (xmlHttp.status = 200 && xmlHttp.readyState == 4) {alert(result);if (result == "true") alert("注册失败,号码存在");else alert("注册成功。");}}
</script>

post方式

电话号码:<input type="text" id = "mobile"/> <br/><button onclick = "postRegister()">注册</button><script type="text/javascript">function postRegister() {		var mobile = document.getElementById("mobile").value;	xmlHttp = new XMLHttpRequest();// 打开服务器连接xmlHttp.open("post", "jsServlet", true);// 设置头信息,有两种,是否上传文件的区别xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");// xmlHttp.setRequestHeader("Content-Type", "multipart/form-data");// 发送数据 key = value 的方式xmlHttp.send("mobile=" + mobile);// 回调函数,执行完这段js后,在调用的函数xmlHttp.onreadystatechange = rollBack;}function rollBack() {var result = xmlHttp.responseText;if (xmlHttp.readyState == 4 && xmlHttp.status == 200) {alert(result);if (result == "true")alert("注册失败,号码已经存在!");elsealert("注册成功。");}}</script>

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

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

相关文章

实验一:写一个hello world小程序

实验一&#xff1a;写一个hello world小程序 注&#xff1a;本课程为网易云课堂孟宁老师《软件工程&#xff1a;C编码实践篇》 的配套实验与作业。请配合 MOOC 课程学习使用。 实验要求 写一个hello world小程序&#xff1a; 在Linux命令行环境&#xff08;实验楼&#xff09;…

前端学习(1043):回车把数据存储到本地存储里面

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>todoList待办事项</title><script src"…

Keen Team

Keen Team (碁震安全研究团队&#xff0c;KeenTeam)是一支由在信息安全理论和技术研究方面全球领先的中国“白帽”安全专家组成的信息安全研究队伍&#xff0c;成员主要来自微软的安全漏洞研究、安全攻击和防御技术研究、安全应急响应团队。目前&#xff0c;KeenTeam是世界范围…

jQuery 实现Ajax

js实现jQuery请看 js实现jQuery 首先得要jQuery库&#xff0c;里面要jQuery所有的版本提供选择 http://www.jq22.com/jquery-info122 jQuery 相当于一个简化js编程的轻量级的类库。 jQuery代码写在JS的function里面以$符号开头&#xff0c;里面有可以有function&#xff0c;有各…

SSH远程登录

原文请参阅阮一峰网络日志&#xff1a;http://www.ruanyifeng.com/blog/2011/12/ssh_remote_login.html SSH是每一台Linux电脑的标准配置。 随着Linux设备从电脑逐渐扩展到手机、外设和家用电器&#xff0c;SSH的使用范围也越来越广。不仅程序员离不开它&#xff0c;很多普通用…

前端学习(1044):本地存储实现数据录入

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>todoList待办事项</title><script src"…

XCode5添加新建类模板(Cocos2dx Template Class for Scene or Layer)

注&#xff1a;以下内容截选自Cocos2D开发网–Cocos2Dev.com&#xff0c;谢谢&#xff01; 怎么添加xcode类模板? 1、打开Xcode的类模板目录地址&#xff1a;/Applications/Xcode.app/Contents/Developer/Library/Xcode/Templates/File Templates 2、打开里面C and C文件&…

Ajax解析JSON文件

Ajax解析后台来json文件&#xff0c;是用jQuery方式实现的。依赖jQuery库。 jQuery库 Coding coming… 需求&#xff1a;从后台发送学生的json对象&#xff0c;输出到前台&#xff0c;依赖Java解析json的jar包。 java解析json 实体类 package com.lovely.entity;public class …

实验12 编写0号中断的处理程序

1&#xff0c;在地址0:200h处安装中断代码&#xff0c;安装程序如下&#xff1a; assume cs:codesgcodesg segment start: mov ax, csmov ds, axmov si, offset do0 ;设置ds:si指向源地址mov ax, 0mov es, ax mov di, 200h ;设置es:si指目的地址mov cx, offset do0end - o…

前端学习(1045):todolist本地存储加载到页面

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>todoList待办事项</title><script src"…

jsp页面路径问题(404)

1&#xff0c;xml文件修改&#xff0c;servlet的地址名没有修改。 2&#xff0c;给定了许多jsp页面&#xff0c;把jsp页面放到项目里面&#xff0c;页面之间不能跳转&#xff0c;又是相对路径&#xff0c;出现了404&#xff0c;用servlet访问&#xff0c;不能转发&#xff0c;要…

前端学习(1046):todolist删除数据1

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>todoList待办事项</title><script src"…

实验13 编写、应用中断

int指令的最终功能和call指令类似&#xff0c;都是调用一段程序 两者的根本区别表现在服务时间和服务对象上不一样。&#xff08;本段叙述参考原文&#xff1a;http://blog.csdn.net/jxq0816/article/details/50121563&#xff09; 1&#xff09;调用子程序发生的时间是已知的…

ORACLE分页查询

先看SQL语句 create table USERS (USER_ID VARCHAR2(10) primary key not null, --登录名USER_NAME VARCHAR2(20) not null,--用户名(昵称)USER_PASSWORD VARCHAR2(20) not null,--密码USER_SEX VARCHAR2(2) not null,--性别USER_BIRTHDAY DATE…

js 谈this

1&#xff09;当在全局作用域下&#xff0c;执行一个函数fun()&#xff0c;局部变量的作用域为该函数&#xff0c;this指向window&#xff0c;实际上相当于执行window.fun()&#xff1b; 2&#xff09;当函数前面加一个对象&#xff0c;利用obj1.fun(),则在fun函数内部&#xf…

实验14:访问CMOS RAM显示当前日期和时间

下面的代码实现的功能是实时的显示时间&#xff0c;显示的效果就如同一个电子时钟&#xff0c;这个代码来自于“网易云课堂”讲汇编的一位老师&#xff08;从0开始&#xff0c;讲的非常的好&#xff09;&#xff0c;这段代码老师写的太好了&#xff0c;贴在下面学习效仿一下&am…

前端学习(1047):todolist删除数据2

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>todoList待办事项</title><script src"…

网页里面的下拉框与数据库交互

对于常用的表单来说&#xff0c;用value取值居多。 而下拉框这个神圣&#xff0c;常用的东西&#xff0c;与servlet交互&#xff0c;就常见啦。 核心就是下拉框的文本改变事件 和 js相结合来传值啦 下面是一个小demo&#xff0c;一个分页的小demo&#xff0c;下拉框绑定了页数。…

C#基础 基本语法4

1、除了基本的OOP技术&#xff0c;还要熟悉一些比较高级的技术。集合、比较、转换。System.Collections名称空间中的几个接口提供了基本的集合功能。IEnumberable;ICollection;IList;IDictionnary2、ArrayList animalArrayListnew ArrayList(); ------------------------------…

实验15 安装新的int 9中断例程

这个实验综合了外中断&#xff0c;内中断&#xff0c;应该是全书最精华的一个实验&#xff0c;常常思考整个程序的流程&#xff0c;指导这个流程觉得熟悉、自然。 代码如下&#xff1a; assume cs:code, ss:stackstack segmentdb 128 dup(0) stack endscode segment start:mov…