javascript如何获取后台数据(JavaScript实现异步获取表单数据)
javascript如何获取后台数据
JavaScript实现异步获取表单数据本文实例为大家分享了JavaScript实现异步获取表单数据的具体代码,供大家参考,具体内容如下
在上一篇文章中讲到了使用JavaScript异步提交表单中的数据,那么今天我们就讲讲利用JavaScript异步获取表单中的数据;话不多说,让我们接着往下看。
效果图如下:
点击获取数据,就可以获取到如下图所示的数据。
HTML部分如下:
<li class="container"> <form class="form-horizontal" onsubmit="return false;"> <li class="form-group"> <label class="control-label col-md-3">姓名:</label> <li class="col-md-4"> <input type="type" name="txtname" value=" " class="form-control" id="txtName"/> </li> </li> <li class="form-group"> <label class="control-label col-md-3">性别:</label> <li class="col-md-4"> <select class="form-control" name="cboSex" id="cboSex"> <option>--请选择</option> <option>男</option> <option>女</option> </select> </li> </li> <li class=" form-group"> <label class="control-label col-md-3">地址:</label> <li class="col-md-4"> <textarea class="form-control" name="txtAddress" id="txtAddress"></textarea> </li> </li> <li class="form-group"> <button class="btn btn-primary col-md-offset-4" onclick="getVal()">获取表单的值</button> <button class="btn btn-primary" onclick="postgetData()">提交数据</button> <button class="btn btn-success" onclick="getData()">获取数据</button> </li> </form> </li>
JavaScript部分如下:
function getData() { var xhr; if (window.XMLHttpRequest) { xhr = new XMLHttpRequest(); } else { xhr = ActiveXObject("microsoft.XMLHTTP"); } xhr.open("post", "/JQuery/getInformation", true); xhr.send(); xhr.onreadystatechange = function () { if (xhr.status == 200 && xhr.readyState == 4) { var txt = xhr.responseText;//获取xhr的返回值 var obj = JSON.parse(txt);//将字符串解析为js对象 document.getElementById("txtName").value = obj.name; document.getElementById("cboSex").value = obj.sex; document.getElementById("txtAddress").value = obj.address; } } }
向服务器发送请求
向服务器发送请求,我们使用 XMLHttpRequest 对象的 open() 和 send() 方法:
open(method,url,async) 规定请求的类型、URL 以及是否异步处理请求。
一、什么是同步与异步?
同步就是指一个进程在执行某个请求的时候,若该请求需要一段时间才能返回信息,那么这个进程将会一直等待下去,直到收到返回信息才继续执行下去。
异步是指进程不需要一直等下去,而是继续执行下面的操作,不管其他进程的状态。
当有消息返回时系统会通知进程进行处理,这样可以提高执行的效率。
异步实现:
1、运用HTML与CSS来实现页面,表达信息
2、运用XMLHttpRequest和web服务器进行数据的异步交换
3、运用JavaScript操作DOM,实现动态局部刷新
二、什么是 XMLHttpRequest 对象?
XMLHttpRequest 对象用于在后台与服务器交换数据(具体介绍可见w3c)
创建 XMLHttpRequest 对象
所有现代浏览器(IE7+、Firefox、Chrome、Safari 以及 Opera)均内建
XMLHttpRequest 对象。
创建 XMLHttpRequest 对象的语法:
var xhr=new XMLHttpRequest();
老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveXObject 对象:
var xhr=new ActiveXObject("Microsoft.XMLHTTP");
为了应对所有的现代浏览器,包括 IE5 和 IE6,请检查浏览器是否支持XMLHttpRequest 对象。如果支持,则创建 XMLHttpRequest 对象。如果不支持,则创建 ActiveXObject:
var xhr; if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari xhr = new XMLHttpRequest(); } else { // code for IE6, IE5 xhr = new ActiveXObject("Microsoft.XMLHTTP"); }
三.向服务器发送请求
向服务器发送请求,我们使用 XMLHttpRequest 对象的 open() 和 send() 方法:
open(method,url,async) 规定请求的类型、URL 以及是否异步处理请求。
控制器方法如下:
public ActionResult getInformation() { string str = "{\"name\":\"三三\",\"sex\":\"男\",\"address\":\"上海市南城区\"}"; return Content(str); }
总结
以上就是今天要讲的内容,本文仅仅简单介绍了异步获取表单数据的使用。
- 微信小程序js 抽奖概率(小程序实现筛子抽奖)
- js基础入门运算符(js 可选链操作符的使用)
- 动态加载js脚本
- js字符串常用函数
- python的decode函数在哪个模块(python中报错"json.decoder.JSONDecodeError: Expecting value:"的解决)
- js解除网页屏蔽(js检测标题与描述中的关键词发现就替换或跳转到别的页面)
- js判断浏览器的版本
- js 图片编辑处理库(javascript input图片上传及预览,FileReader预览图片)
- docker node 分阶段构建(Docker安装、创建镜像、加载并运行NodeJS程序的详细过程)
- ExtJs中XTemplate使用
- python class转json(Python对象转换为json的方法步骤)
- js函数对象
- python操作json格式(详解python 3.6 安装json 模块simplejson)
- vue购物车怎么实现(Vue.js框架实现购物车功能)
- node.js怎么使用import(Node.js断点续传的实现)
- mysql存储json的方式(MySQL中查询json格式的字段实例详解)
- 缅甸旅游攻略(缅甸旅游攻略必去景点推荐)
- 《庆余年2》新消息,原班人马,肖战特别出演,这才是最好的安排(庆余年2新消息原班人马)
- 宁夏灵武恐龙化石发现始末(宁夏灵武恐龙化石发现始末)
- 到了岁末 临门一脚 节点,天台综合督评会目标直指 全年红(到了岁末临门一脚)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
热门推荐
- python直接查询mongodb(pymongo中聚合查询的使用方法)
- mysqlupdate怎么设置(MySQL update 语句的正确用法)
- 使用docker对集群进行管理(使用docker搭建kong集群操作)
- 使用mui制作页面案例(Yii框架页面渲染操作实例详解)
- python pyqt 教程(Python+PyQt5实现美剧爬虫可视工具的方法)
- 颜色识别模块抓取物体(Referer原理与图片防盗链实现方法详解)
- css3特效旋转菜单(CSS3实现的水平标题菜单)
- mysql客户端怎么运行程序(MySQL 如何连接对应的客户端进程)
- python怎么设置matlab编程(实例详解Matlab 与 Python 的区别)
- idea里面怎么配置tomcat(intellij idea 使用Tomcat部署的项目位置在哪)