jQuery学习笔记(1)--用jQuery实现异步通信(用json传值)具体思路
2013-04-08 00:00
746 查看
jQuery是时下比较流行的一个js库,能够用简单的代码做出理想的效果,就像官网上说的那样“write less ,do more”。Jquery在一定程度上改写了以往对JavaScript的写法,本人就用jquery实现上篇中用ajax实现异步通信的效果,感受一下jquery的魅力。
首先你需要下载jquery的最新的js文件,并将其引入到文件中,你也可以在此下载:点我下载。
这次通信用的是jquery的jQuery.post(url,[data], [callback],[type])方法,这是一个简单的POST 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。参数为:url,[data],[callback],[type] 相对应的参数类型为String,Map,Function,String:
●url:发送请求地址。
●data:待发送 Key/value参数。
●callback:发送成功时回调函数。
●type:返回内容格式,xml,html, script, json, text, _default)
新建一个jsp文件jqueryDemo.jsp,代码如下所示:
新建一个servlet文件JqueryServlet.java,代码如下所示:
好了,现在可以运行了,打开服务器,运行此jsp文件,页面如下所示:
当输入admin时,页面如下所示:
当输入其他的字符时,页面如下所示:
可以看出jquery能够实现ajax的功能,并且代码更简洁了。
只是,最后本人有一个问题迟迟没有解决,那就是输入中文时传到后台的值乱码,按照网上的好多办法都没有解决掉,不知道为什么,谁有更好的方法希望能给我推荐一下,本人不胜感激。
这是本人学习的结果,允许转载,欢迎交流,但转载务必给出本文章的链接地址
首先你需要下载jquery的最新的js文件,并将其引入到文件中,你也可以在此下载:点我下载。
这次通信用的是jquery的jQuery.post(url,[data], [callback],[type])方法,这是一个简单的POST 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。参数为:url,[data],[callback],[type] 相对应的参数类型为String,Map,Function,String:
●url:发送请求地址。
●data:待发送 Key/value参数。
●callback:发送成功时回调函数。
●type:返回内容格式,xml,html, script, json, text, _default)
新建一个jsp文件jqueryDemo.jsp,代码如下所示:
<%@ page language="java"contentType="text/html; charset=GB18030" pageEncoding="GB18030"%> <!DOCTYPE html PUBLIC "-//W3C//DTDHTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type"content="text/html; charset=GB18030"> <title>jquery</title> <style type="text/css"> table.demo{border-collapse: collapse;margin-top: 50px;margin-left: 220px;} table.demo th,td {padding: 0; border: 1px solid #000;} #img,#msg{position: static;float: left;} #account,#password1,#password2{margin-left: 10px;} #img{margin-left: 10px;} </style> <script type="text/javascript" src="jquery/jquery-1.7.2.min.js"></script> <script type="text/javascript"> function accountCheck(){ var account=$('#account').val(); if(account==""){ alert("用户帐号不能为空!"); $('#img').html(""); $('#msg').text(""); return; } $.post('JqueryServlet',{strAccount:account},function(data){ eval("data="+data); if(data.success){ $('#img').html("<img src='img/cross.png'/>"); }else{ $('#img').html("<img src='img/tick.png'/>"); } $('#msg').text(data.msg); }); } </script> </head> <body> <form action=""method="post" > <table class="demo" style="width: 450px;height: 200px;"> <tr> <td colspan=3 align=center>新用户注册</td> </tr> <tr> <td style="width:90px; ">用户帐号:</td> <td style="width:185px; "><input type="text"id="account" name="account"onblur="accountCheck();"><font color=red>*</font></td> <td style="width:175px; "> <div id="img" class="img"></div> <div id="msg"class="msg"></div> </td> </tr> <tr> <td>用户密码:</td> <td><input type="password"id="password1" name="password1"></td> <td></td> </tr> <tr> <td>重复密码:</td> <td><input type="password"id="password2" name="password2"></td> <td></td> </tr> <tr> <td colspan=3 align=center><input type="submit"value="注册"></td> </tr> </table> </form> </body> </html>
新建一个servlet文件JqueryServlet.java,代码如下所示:
package com.ldfsoft.servlet; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; importjavax.servlet.http.HttpServletRequest; importjavax.servlet.http.HttpServletResponse; /** *Servlet implementation class JqueryServlet */ public class JqueryServlet extendsHttpServlet { privatestatic final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public JqueryServlet() { super(); // TODO Auto-generated constructor stub } /** * @see HttpServlet#service(HttpServletRequestrequest, HttpServletResponse response) */ protectedvoid service(HttpServletRequest request, HttpServletResponse response) throwsServletException, IOException { //TODO Auto-generated method stub request.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=utf-8"); String account=request.getParameter("strAccount"); PrintWriter out=response.getWriter(); String str=""; //用以json传值 if(account.equals("admin")){ str="{success:true,msg:'该账户已存在'}"; }else{ str="{success:false,msg:'该账户可以使用'}"; } out.write(str); } }
好了,现在可以运行了,打开服务器,运行此jsp文件,页面如下所示:
当输入admin时,页面如下所示:
当输入其他的字符时,页面如下所示:
可以看出jquery能够实现ajax的功能,并且代码更简洁了。
只是,最后本人有一个问题迟迟没有解决,那就是输入中文时传到后台的值乱码,按照网上的好多办法都没有解决掉,不知道为什么,谁有更好的方法希望能给我推荐一下,本人不胜感激。
这是本人学习的结果,允许转载,欢迎交流,但转载务必给出本文章的链接地址
相关文章推荐
- jQuery学习笔记(1)--用jQuery实现异步通信(用json传值)具体思路
- 用jQuery实现异步通信(用json传值)具体思路
- jQuery学习笔记(1)----用jQuery实现异步通信(用json传值)
- jQuery学习笔记(4)--Jquery中获取table中某列值的具体思路
- ajax,json学习笔记(三)JSON和jquery实现ajax
- jQuery学习笔记(2)--用jquery实现各种模态提示框代码及项目构架
- 持续集成学习笔记-入门篇(5)持续集成自动化(二):具体实现方式一
- 【Spring学习笔记-MVC-18.1】Spring MVC实现RESTful风格-同一资源,多种展现:xml-json-html
- 用jQuery实现瀑布流效果学习笔记
- jquery监听div内容的变化具体实现思路
- React学习笔记:使用jquery实现动画效果淡入淡出
- 【JAVAWEB学习笔记】28_jquery加强:json数据结构、jquery的ajax操作和表单校验插件
- MVC学习笔记之:ASP.NET MVC的客户端验证-jQuery.validate验证集合Model验证中的实现
- AJAX学习之序列二:struts2 jquery json 实现AJAX 注册ID验证
- Android 学习笔记之Volley(七)实现Json数据加载和解析...
- jQuery学习笔记(3)----用jquery实现多选项卡功能
- jQuery学习笔记--ajax查询,jQuery解析返回的json数据 详解
- Struts学习笔记(三):Ajax +json+JQuery的综合使用
- jquery+css+ul模拟列表菜单具体实现思路