100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > ajax如何跳转到新的jsp页面的实现方法

ajax如何跳转到新的jsp页面的实现方法

时间:2018-12-21 04:27:42

相关推荐

ajax如何跳转到新的jsp页面的实现方法

web前端|js教程

javascript,ajax,面的

web前端-js教程

ajax可以实现局部刷新页面,即在不刷新整个页面的情况下更新页面的局部信息。

网络爬虫源码,vscode前端如何调试,ubuntu 禁止升级,tomcat的进程名称,光速爬虫,php file()函数,本地seo推广公司排名,药品录入系统网站源码,个人网站模板含后台免费下载lzw

项目中遇到一个问题:在用户列表也,当点击某个按钮时需要去查询用户的信息,查询成功跳转到用户详情界面;查询失败,则在原页面弹出提示信息。

任务跟进系统源码,ubuntu 自动搜索驱动,爬虫设计与实施,关于php前言,玉林站内seolzw

想到两个解决办法:

电脑微信 源码,vscode英文改中文,ubuntu改变窗口,tomcat猫包,SQLite查表中列数,电商爬虫数据的处理流程,php 后台搭建,金华网络优化seo,大淘客cms优惠券网站,网页炫酷相册源码,html优特网站模板lzw

方法一:

点击按钮,调用普通方法去查询用户信息,查询成功跳转到用户详情页面;查询失败,重定向调用查询用户列表的方法,在查询用户列表的方法结束后重新跳转到用户列表页面并弹出提示信息,相当于重新加载了用户列表页面。

方法二:

根据需求,不可以重新加载用户列表页面。用ajax调用查询用户详情的方法,查询成功返回用户Json串,查询失败则返回error。

后台方法:

@RequestMapping(value = "searchUser") public void searchHome(HttpServletResponse response){ String result = null; ... 查询用户的方法 ...if(查询成功){ result = JsonUtil.objectToJson(查询结果对象);//结果对象转化成Json字符串,在ajax的结果中跳转到用户详情的处理方法 AjaxUtil.ajax(response,result); }else{//查询失败,返回提示信息 AjaxUtil.error(response, "查询用户失败"); } }

jsp页面的ajax:

function searchUser(){$.ajax({ url : "testurl/searchUser", cache : false, type : POST, data : {查询用的数据,比如用户ID }, success : function(data) {var obj = eval("("+data+")"); if(obj.success==undefined){//查询成功,跳转到详情页面 ... 跳转到用户详情处理方法,将date数据传过去 ...}else if(!obj.success){//查询失败,弹出提示信息 weui.Loading.info(obj.message);} }, error : function(error) {weui.alert("查询用户有误!"); }});}

此处的重点在于如何在ajax的回调函数中调用普通方法,并将之前查询出的用户数据传到普通方法中(上面伪代码中红色的部分),继而跳转到用户详情页面。

(1)错误案例:

function searchUser(){$.ajax({ url : "testurl/searchUser", cache : false, type : POST, data : { 查询用的数据,比如用户ID }, success : function(data) { var obj = eval("("+data+")"); if(obj.success==undefined){//查询成功,跳转到详情页面,encodeURIComponent编码是为了防止url后面传送的参数中文乱码,在后台处理时需要解码 window.location.href = "testurl/userForm?userJson="+encodeURIComponent(data); }else if(!obj.success){//查询失败,弹出提示信息 weui.Loading.info(obj.message); } }, error : function(error) { weui.alert("查询用户有误!"); }}); }

错误原因:window.location.href方法为get方法,这会使得参数显示的浏览器的url中,不安全,并且数据传送的长度有限制。

(2)想到的笨方法:在body中写隐藏的form表单,在回调函数中把查到的用户数据复制给form表单中的input,然后提交表单跳转到普通方法中,这样就是以post方法提交的数据,并且可以跳转到新页面了:

function searchUser(){$.ajax({ url : "testurl/searchUser", cache : false, type : POST, data : { 查询用的数据,比如用户ID }, success : function(data) { var obj = eval("("+data+")"); if(obj.success==undefined){//查询成功,跳转到详情页面 $("#userFormJson").val(data); $("#userForm").attr("action","testurl/userForm"); $("#userForm").submit(); }else if(!obj.success){//查询失败,弹出提示信息 weui.Loading.info(obj.message); } }, error : function(error) { weui.alert("查询用户有误!"); }}); }

jsp页面的body

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。