网站模板库
  • 首页
  • web前端工具
    • HTML/JS转换工具
    • JS/HTML格式化工具
    • 字母/英文大小写转换工具
    • robots.txt文件生成工具
    • Js压缩/格式化工具
    • Css在线压缩工具_代码格式化
  • 关于我们
    • 免责声明
    • 联系我们
    • 广告服务
    • 服务项目
    • 关于我们
    • 网站轮播
    • 公告
    • 成都优优科技专用
    • 按行业分类
  • web学院
    • 服务器教程
    • 学习资料
      • 基础书籍
      • 交互书籍
      • 入门教程
      • 特效分类
    • 案例分享
    • web资讯
  • 网页特效
    • 图片特效
    • 导航特效
    • 滑动按钮
    • 表单特效
    • 文字特效
    • 弹窗特效
    • 其他特效
  • 织梦模板
    • 科技/电子/数码/通信
    • 文化/艺术/广告/传媒
    • 装修/设计/家居/家具
    • 基建/施工/地产/物业
    • 餐饮/酒店/旅游/票务
    • 食品/果蔬/饮料/日用
    • 服饰/珠宝/礼品/玩具
    • 摄影/婚庆/家政/生活
    • 运动/健身/体育/器材
    • 学校/教育/培训/科研
    • 美容/保健/医院/医疗
    • 金融/财税/咨询/法律
    • 政府/组织/集团/协会
    • 汽车/物流/交通/搬运
    • 机械/设备/制造/仪器
    • 化工/环保/能源/材料
    • 农业/畜牧/养殖/宠物
    • 其他模版
    • IT/软件/信息/互联网
  • 手机模板
    • 手机APP模板
    • 微信小程序模板
    • wap
  • 网站模板
    • joomla模板
    • Drupal模板
    • z-blog模板
    • EyouCms模板
    • Bootstrap模板
    • 帝国cms模板
    • CmsEasy模板
    • MetInfo模板
    • 购物商城模板
      • Shopify主题
      • PrestaShop主题
    • 后台模板
    • 纯HTML模板
    • ecshop模板
    • phpwind模板
    • pbootcms模板
    • phpcms模板
    • wordpress模板
    • discuz模板
  • 教程
    • 织梦教程
    • Discuz教程
    • WordPress教程
    • Phpcms教程
    • Phpwind教程
    • ECShop教程
    • Joomla教程
    • Drupal教程
    • zblog教程
    • EyouCMS教程
    • 帝国cms教程
    • MetInfo教程
    • CmsEasy教程
登录
当前位置:网站模板库 > web学院 > 服务器教程 > jquery里ajax中怎么将函数中的数据提取出来,放在另外一个其他函数中使用?
商业源码 服务器教程 2024-01-17 4:55:02

jquery里ajax中怎么将函数中的数据提取出来,放在另外一个其他函数中使用?

jquery里ajax中怎么将函数中的数据提取出来,放在另外一个其他函数中使用?,第1张

1、新建一个html文件,命名为testhtml。

2、在testhtml文件内,使用form标签创建一个表单,并使用input创建一个用户名输入框,一个密码输入框。

3、在testhtml文件内,创建一个button按钮,用于点击提交表单内容,当按钮被点击时,执行subform()函数。

4、在js标签内,创建subform()函数,在函数内,通过id分别获得文本框和密码框对象,通过val()方法获得输入的内容。

5、在js标签内,使用“$ajax()”来实现ajax提交表单内容。url为提交数据至服务器的连接,type为传输数据的类型,data为数据的内容,success为服务器接收数据后返回的内容,通过if实现提交成功与否的判断。

6、在浏览器打开testhtml文件,点击按钮,查看结果。

本文给大家分享一下,如何使用ajax读取Json中的数据。

一、基础知识

什么是json?

JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)

JSON 是轻量级的文本数据交换格式

JSON 独立于语言

JSON 具有自我描述性,更易理解

JSON 使用 JavaScript 语法来描述数据对象,但是 JSON 仍然独立于语言和平台。JSON 解析器和 JSON 库支持许多不同的编程语言。

JSON - 转换为 JavaScript 对象

JSON 文本格式在语法上与创建 JavaScript 对象的代码相同。

由于这种相似性,无需解析器,JavaScript 程序能够使用内建的 eval() 函数,用 JSON 数据来生成原生的 JavaScript 对象。

二、读取Json中的数据

首先我编写了一个Json的文件,里面有内容。注意格式。

图一 编写json的文件

然后,编写html代码,并引用ajax。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 10 Transitional//EN" "http://wwww3org/TR/xhtml1/DTD/xhtml1-transitionaldtd">

<html xmlns="http://wwww3org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>使用AJAX异步读取json</title>

<script src="ajaxjs">

</script>

<script>

windowonload=function()

{

/获得按钮/

var aBtn=documentgetElementById('btn1');

//给按钮添加点击事件

aBtnonclick=function()

{

//调用ajax函数

ajax('datajson',function(str){

//将JSON 数据来生成原生的 JavaScript 对象

var arr=eval(str);

alert(arr[0]b);

});

};

};

</script>

</head>

<body>

读取json里面的数据 <br />

<input id="btn1" type="button" value="读取json里面的数据" />

</body>

</html>

封装的AJAX函数代码如下:

/

AJAX封装函数

url:系统要读取文件的地址

fnSucc:一个函数,文件取过来,加载完会调用

/

function ajax(url, fnSucc, fnFaild)

{

//1创建Ajax对象

var oAjax=null;

if(windowXMLHttpRequest)

{

oAjax=new XMLHttpRequest();

}

else

{

oAjax=new ActiveXObject("MicrosoftXMLHTTP");

}

//2连接服务器

oAjaxopen('GET', url, true);

//3发送请求

oAjaxsend();

//4接收服务器的返回

oAjaxonreadystatechange=function ()

{

if(oAjaxreadyState==4) //完成

{

if(oAjaxstatus==200) //成功

{

fnSucc(oAjaxresponseText);

}

else

{

if(fnFaild)

fnFaild(oAjaxstatus);

}

}

};

}

接下来就是要读取出文件内容,在这之前,有一点要提的是,AJAX是从服务器上读取文件,所以要把写好的JSON文件放到服务器的路径下,可能初学者接触过的服务器只有IIS,他的文件路径是C:\inetpub\wwwroot\aspnet_client\system_web,只要把Json放到这个路径下,然后用localhost来访问服务器,就可以了。

图二 读取效果图

1原生AJAX代码

get请求:

//创建xhr,IE低版本不支持

var xhr = new XMLHttpRequest();

//servlet地址

var url="/Website01/indexview";

xhropen("get", url, true);

//xhr处理事件,异步

xhronreadystatechange = function() {

if (xhrreadyState == 4 && xhrstatus == 200) {

//在这里进行相关处理,通过xhrresponseText获取后台反馈的文本

}

};

//xhr发送数据

xhrsend();

post请求:

post请求需注意要设置请求头(setRequestHeader)

xhrsetRequestHeader(“Content-type”, “application/json”);针对JSON数据

在xhrsend()中写需要发送的JSON数据,例如:

xhrsend(JSONstringify(data));1

2Servlet基础知识

Servlet是用Java编写的服务器端程序。其主要功能在于交互式地浏览和修改数据,生成动态Web内容。狭义的Servlet是指Java语言实现的一个接口,广义的Servlet是指任何实现了这个Servlet接口的类,一般情况下,人们将Servlet理解为后者。

Servlet运行于支持Java的应用服务器中(Tomcat)。从原理上讲,Servlet可以响应任何类型的请求,但绝大多数情况下Servlet只用来扩展基于HTTP协议的Web服务器。

在Java中,新建Servlet类继承自HttpServlet,重写doGet方法处理get请求,重写doPost方法,处理post请求,通过

PrintWriter out = responsegetWriter();通过outwrite()输出数据到前台的xhrresponseText,通过outprintln()输出页面。

3Servlet处理请求

处理请求通过HttpServletRequest类型,Get请求时查询字符串直接编码在请求链接中,格式为url+”key1=value1&key2=value2”,通过getParameter(“key1”)来获取值。

4前后端传递JSON数据

前端传递JSON给Servlet

//程序片段,请求头不能少

xhrsetRequestHeader("Content-type", "application/json");

var data={"name":"Tom","age":20};

xhrsend(JSONstringify(data));1234

后端接受前端传递的JSON数据

//读取请求传递过来的JSON格式数据,返回JSON字符串

private String readJSONData(HttpServletRequest request) {

StringBuffer json=new StringBuffer();

String lineString=null;

try {

BufferedReader reader=requestgetReader();

while ((lineString=readerreadLine())!=null) {

jsonappend(lineString);

}

} catch (Exception e) {

Systemoutprintln(etoString());

}

return jsontoString();

}

String json=readJSONData(request);

//将json字符串转为java对象

Gson gson=new Gson();

Person person=gsonfromJson(json, Personclass);

说明

Gson为google处理JSON格式数据的jar包,可将JSON字符串转换为对应的Java对象,也可将相应的Java对象序列化为JSON字符串。Person为定义的类,包含name和age字段。readJSONData函数将前端请求中的JSON数据转为java对象。

后端输出JSON到前端

//后端程序片段,传递json数据给前端

Person person=new Person("Tom",20);

Gson gson=new Gson();

String json=gsontoJson(person);

outwrite(json);

//前端程序片段,通过ajax获取json数据

var xhr = new XMLHttpRequest();

var url="/Website01/indexview";

xhropen("get", url, true);

xhronreadystatechange = function() {

if (xhrreadyState == 4 && xhrstatus == 200) {

//获取后台传递过来的字符串并转换为json

var responseJson=JSONparse(xhrresponseText);

var name=responseJsonname;

var age=responseJsonage;

}

};

xhrsend(null);

5表单数据的处理

<form method="post" action="/Website01/indexview">

<label>Name:</label><input type="text" id="name1" name="name"><br>

<label>Age:</label><input type="number" id="age1" name="age"><br>

<input type="submit" id="submit" value="提交">

</form>12345

表单数据可以直接在form属性中定义请求方法和请求路径,在点击submit按钮后数据会直接提交并跳转。如上的表单,在点击按钮提交后,后台使用requestgetParameter(“key”)获取数据,key值为input标签的name值,而非id值,即通过以下代码获取表单提交的数据。

String name=requestgetParameter("name");

String age=requestgetParameter("age");12

以上。

  写js调用jqueryformjs,对form表单进行ajax提交

  $(document)ready(function() {

var options = {

target: '#output1',

// 从服务传过来的数据显示在这个div内部

也就是ajax局部刷新

beforeSubmit: showRequest,

// ajax提交之前的处理

success: showResponse

// 处理之后的处理

};

$('#showDataForm')submit(function() {

$(this)ajaxSubmit(options);

return false;

//非常重要,如果是false,则表明是不跳转

//在本页上处理,也就是ajax,如果是非false,则传统的form跳转。

});

});

$ajax({

type: 'get', //ajax的方式 get/post

cache: false, //是否缓存

dataType: 'json', //接收返回数据的方式

url: "<=site_url('vod/admin/vod/type_i')>"+stype, //路径

timeout: 3000, //超时时间

success:function(data){ //成功后返回的回调方法

var json // data就是后台返回的数据

}

})

第一个问题:先搞清ajax的底层通信形式,ajax发出请求后等待回复,也就是监听某个信息端口,服务器接到请求后,发送结果,也就是向某个端口写信息,所以,不管在形式上编程上有什么不同,都是向这个ajax所在地的信息端口输出信息。

第二个问题,response==0是将response转换为int类型再对比,肯定正确,而response肯定不等于"0",因为outprintln("0"),println这个方法就是在输出的字符串后加一个回车,你可以将response转换为ascii码看看是不是这样。

ajax是客户端获取服务器上数据的方法

EL表达式利用的是服务器上的数据

显然,EL表达式是不可能获取ajax请求得到的数据的

千万要谨记:JSP也是servlet,它是不可能直接跟JS产生交互的,自然也无法利用JS取到的数据

数据 对象 函数 文件 表单
DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » jquery里ajax中怎么将函数中的数据提取出来,放在另外一个其他函数中使用?

商业源码 钻石

分享到:
上一篇
服务器的作用是什么?
下一篇
如何搭建网站服务器?

相关推荐

浅谈审计数据采集方法

浅谈审计数据采集方法

苹果手机无法与服务器建立安全连接?

苹果手机无法与服务器建立安全连接?

discuz论坛版块页面打开后全部出现404错误是怎么回事?

discuz论坛版块页面打开后全部出现404错误是怎么回事?

时间切片设置超出数据范围

时间切片设置超出数据范围

0条评论

发表评论 取消回复

要发表评论,您必须先登录。

提供最优质的资源集合

立即查看 了解详情
网站模板库

主题/付费下载/查看/余额管理/自定义积分,集成支付,卡密,推广奖励等。

本站导航
  • 链接标题
友情链接
  • 链接标题
快速搜索
本站由钛宇宙强力驱动
友情链接:
    商业源码网蜀ICP备2023005044号
    网站模板库
    • 登录
    • 注册
    网站模板库
    • 首页
    • web前端工具►
      • HTML/JS转换工具
      • JS/HTML格式化工具
      • 字母/英文大小写转换工具
      • robots.txt文件生成工具
      • Js压缩/格式化工具
      • Css在线压缩工具_代码格式化
    • 关于我们►
      • 免责声明
      • 联系我们
      • 广告服务
      • 服务项目
      • 关于我们
      • 网站轮播
      • 公告
      • 成都优优科技专用
      • 按行业分类
    • web学院►
      • 服务器教程
      • 学习资料►
        • 基础书籍
        • 交互书籍
        • 入门教程
        • 特效分类
      • 案例分享
      • web资讯
    • 网页特效►
      • 图片特效
      • 导航特效
      • 滑动按钮
      • 表单特效
      • 文字特效
      • 弹窗特效
      • 其他特效
    • 织梦模板►
      • 科技/电子/数码/通信
      • 文化/艺术/广告/传媒
      • 装修/设计/家居/家具
      • 基建/施工/地产/物业
      • 餐饮/酒店/旅游/票务
      • 食品/果蔬/饮料/日用
      • 服饰/珠宝/礼品/玩具
      • 摄影/婚庆/家政/生活
      • 运动/健身/体育/器材
      • 学校/教育/培训/科研
      • 美容/保健/医院/医疗
      • 金融/财税/咨询/法律
      • 政府/组织/集团/协会
      • 汽车/物流/交通/搬运
      • 机械/设备/制造/仪器
      • 化工/环保/能源/材料
      • 农业/畜牧/养殖/宠物
      • 其他模版
      • IT/软件/信息/互联网
    • 手机模板►
      • 手机APP模板
      • 微信小程序模板
      • wap
    • 网站模板►
      • joomla模板
      • Drupal模板
      • z-blog模板
      • EyouCms模板
      • Bootstrap模板
      • 帝国cms模板
      • CmsEasy模板
      • MetInfo模板
      • 购物商城模板►
        • Shopify主题
        • PrestaShop主题
      • 后台模板
      • 纯HTML模板
      • ecshop模板
      • phpwind模板
      • pbootcms模板
      • phpcms模板
      • wordpress模板
      • discuz模板
    • 教程►
      • 织梦教程
      • Discuz教程
      • WordPress教程
      • Phpcms教程
      • Phpwind教程
      • ECShop教程
      • Joomla教程
      • Drupal教程
      • zblog教程
      • EyouCMS教程
      • 帝国cms教程
      • MetInfo教程
      • CmsEasy教程

      弹窗标题

      这是一条网站公告,可在后台开启或关闭,可自定义背景颜色,标题,内容,用户首次打开关闭后不再重复弹出,此处可使用html标签...