ajax接收json数据到js解析
来源:互联网 发布:广电网络是国企吗 编辑:程序博客网 时间:2024/06/05 22:37
今天又学到了一点新知识,脑子记不住东西特把它记录下来!
页面ajax请求后台时一般都是返回字符串进行判断,要是返回list或者对象时该怎么办?
第一种:ajax接收到list并返回给前台
js代码:
function test(obj){var str = $("#tt").val();webTest(str,function(result){alert(result);//将后台返回结果alert一下var list = eval(result);//解析jsonfor(var i = 0;i < list.length;i++){//循环遍历数据var userinfo = list[i];alert(userinfo.name+"+"+userinfo.age+"+"+userinfo.sex+"+"+userinfo.address);}});}上面红字webTest方法(这里是调用webservice,和ajax处理流程一样)
var webTest = function (test, callback) { var soapMessage = '<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:bs="http://inter.hs.com/">' + '<soapenv:Header/>' + '<soapenv:Body>' + '<bs:test>' + '<para>' + test + '</para>' + '</bs:test>' + '</soapenv:Body>' + '</soapenv:Envelope>'; PostData(soapMessage, callback);}
后台代码:
@Overridepublic String test(String str) {List<UserInfo> list = new ArrayList<UserInfo>();UserInfo ui = new UserInfo();ui.setName("tom");ui.setAge(22);ui.setSex("男");ui.setAddress("陕西西安");list.add(ui);JSONObject ja = JSONObject.fromObject(list);//将list包装成json传递给前台return ja.toString();}运行结果:
第二种情况,接收对象数据返回:
js代码:
<script> $("div.submit_op>input").click(function(){ var uname = $("#acount").val(); var pass = $("#pass").val(); if(uname==""){ alert("请输入用户名"); }else if(pass == ""){ alert("请输入密码"); }else{ ecLogin(uname,pass,function(result){//这一步可以堪称是ajax请求后台,result是返回结果 if(result == "false"){ alert("用户名或者密码错误"); }else{ var userinfo = eval(result)[0];//当是单个对象时,虽不用循环遍历,但是需要【0】取</span> alert(userinfo.user_reg_id); } }); } })</script>
/** * 登录接口 * @param phone 手机号 * @param pass 密码 * @param callback func 回调函数,原型function(string) 其中参数为登录之后的用户对象或者null * @returns */var ecLogin = function (phone, pass, callback) {alert(phone); var soapMessage = '<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:bs="http://inter.hs.com/">' + '<soapenv:Header/>' + '<soapenv:Body>' + '<bs:login>' + '<phone>' + phone + '</phone>' + '<pass>' + pass + '</pass>' + '</bs:login>' + '</soapenv:Body>' + '</soapenv:Envelope>'; PostData(soapMessage, callback);}后台代码:
@Overridepublic String login(String strPhone, String password) {String str = "false";Connection conn = DBManager.getConnection();String sql = "select * from tb_user_login where user_phone = ? and user_pwd = ?";PreparedStatement ps = null;ResultSet rs = null;try {ps = conn.prepareStatement(sql);ps.setString(1, strPhone);ps.setString(2, password);rs = ps.executeQuery();while (rs.next()){UserLogin ul = new UserLogin();ul.setUser_reg_id(rs.getString(1));ul.setUser_phone(rs.getString(2));JSONObject ja = JSONObject.fromObject(ul);str = ja.toString();}} catch (SQLException e) {e.printStackTrace();}return str;}
如有不对,还请各位大牛指正!
0 0
- ajax接收json数据到js解析
- ajax json 前台传数据到后台,后台接收并返回json 数据
- 用户端接收解析JSON数据
- ajax解析JSON数据
- 从servlet获得json数据Ajax解析到前台网页
- ajax提交json数据到后端C#解析
- 浅析ajax请求json数据并用js解析(示例分析)
- 用原生js,json解析ajax传回来的数据
- ajax 传json到后台servlet接收
- jquery eval()解析JSON,ajax通过return返回数据,js读取解析JSON数据
- [JS笔记]$.ajax传JSON数据到后台的注意事项
- 原生js的Ajax提交json数据到后台
- PHP接收POST数据,解析json数据
- PHP接收POST数据,解析json数据
- ajax 接收json,xml类型数据
- ajax接收遍历处理json格式数据
- ThinkPHP Ajax 接收后台Json数据
- springmvc接收ajax的json格式数据
- Java -- HashMap的四种遍历方式
- 微信小程序对WEB前端程序员有何影响
- Java String类和StringBuilder初步认识
- 截图工具 snip
- spark 多目录输出
- ajax接收json数据到js解析
- SAP银企直联解决方案
- 用c#绘制曲线图
- 基于脚本的攻击或可绕过微软的反恶意软件扫描接口(AMSI)
- android 控件 scrollview嵌套listview只显示一行
- 云计算时代:传统it都理解错的“GET 与 POST 的区别”你造吗?
- Android控件架构以及setContentView()方法剖析
- 我踩的thymeleaf渲染框架的坑
- Mybatis中javaType和jdbcType对应关系