页面A跳转到页面B及携带参数

页面A跳转到页面B及携带参数

window.location.href="…/SystemInfoJsp/add_user.jsp?"+“id=”+id+"&name="+name+"&grade="+grade;
解释:

"…/SystemInfoJsp/add_user.jsp?"这个为你要跳转的页面地址,后面追加参数的话要写上?

“id=”+id+"&name="+name+"&grade="+grade 这里为你要传到另外一个页面的数据,是键值对的形式,多个值之间用&符号隔开

页面B获取A页面跳转传递过来的参数

$(function() {
var loc = location.href;//获取整个跳转地址内容,其实就是你传过来的整个地址字符串
console.log(“我的地址”+loc);
var n1 = loc.length;//地址的总长
var n2 = loc.indexOf("?");//取得=号的位置
var parameter = decodeURI(loc.substr(n2+1, n1-n2));//截取从?号后面的内容,也就是参数列表,因为传过来的路径是加了码的,所以要解码
var parameters = parameter.split("&");//从&处拆分,返回字符串数组
console.log(“参数列表”+parameters);
var paValue = new Array();//创建一个用于保存具体值得数组
for (var i = 0; i < parameters.length; i++) {
console.log(“参数键值对值”+i+":"+parameters[i]);
var m1 = parameters[i].length;//获得每个键值对的长度
var m2 = parameters[i].indexOf("=");//获得每个键值对=号的位置
var value = parameters[i].substr(m2+1, m1-m2);//获取每个键值对=号后面具体的值
paValue[i] = value;
console.log(“参数值”+i+":"+value);
}
console.log(“具体参数数组:”+paValue);
});
要获取到你传过来的数据,可以通过数组paValue[index]的方式获取参数,比如上面我传过来了id,name,grade三个参数,那么paValue[0]就是id的值,paValue[1]就是name的值,paValue[2]就是grade的值。

注意:

因为这个paValue数组写在了 ( f u n c t i o n ( ) ) 里 面 , 所 以 要 想 获 得 这 个 数 组 的 值 , 那 么 你 的 代 码 就 得 继 续 写 在 这 个 (function() { })里面,所以要想获得这个数组的值,那么你的代码就得继续写在这个 (function())(function() { })里面。不能再写一个 ( f u n c t i o n ( ) ) , 在 新 写 的 里 面 去 调 这 个 数 组 , 如 果 要 想 在 新 的 (function() { }),在新写的里面去调这个数组,如果要想在新的 (function())(function() { })里面或者是之前$(function() { })之外的方法中调用这个值,可以把var paValue = new Array();这句话写成全局变量,这样其他的就可以用了。如下:

var paValue = new Array();//创建一个用于保存具体值得数组
$(function() {
var loc = location.href;//获取整个跳转地址内容,其实就是你传过来的整个地址字符串
console.log(“我的地址”+loc);
var n1 = loc.length;//地址的总长
var n2 = loc.indexOf("?");//取得=号的位置
var parameter = decodeURI(loc.substr(n2+1, n1-n2));//截取从?号后面的内容,也就是参数列表,因为传过来的路径是加了码的,所以要解码
var parameters = parameter.split("&");//从&处拆分,返回字符串数组
console.log(“参数列表”+parameters);
for (var i = 0; i < parameters.length; i++) {
console.log(“参数键值对值”+i+":"+parameters[i]);
var m1 = parameters[i].length;//获得每个键值对的长度
var m2 = parameters[i].indexOf("=");//获得每个键值对=号的位置
var value = parameters[i].substr(m2+1, m1-m2);//获取每个键值对=号后面具体的值
paValue[i] = value;
console.log(“参数值”+i+":"+value);
}
console.log(“具体参数数组:”+paValue);
});

作者:IT_CREATE
来源:CSDN
原文:https://blog.csdn.net/IT_CREATE/article/details/85327497
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在uniapp中,页面跳转后未更新的问题可能是由于页面缓存导致的。默认情况下,uniapp会对页面进行缓存,以提高页面的加载速度。因此,当从页面A跳转页面B并携带参数后,再从页面B返回页面A时,页面A并不会重新加载,而是直接显示之前的缓存内容。 要解决这个问题,可以在页面B的生命周期函数中使用`onShow`来监听页面显示的事件,并在该事件中重新获取数据。这样,当从页面C返回页面B时,页面B会重新加载并获取最新的数据。 示例代码如下: ```javascript // 页面B的代码 export default { data() { return { id: '' // 假设id是需要传递的参数 } }, onShow() { // 在页面显示时重新获取数据 this.getData(); }, methods: { getData() { // 根据id请求数据的逻辑 } } } ``` 通过在页面B的`onShow`生命周期函数中重新获取数据,可以确保每次从页面C返回页面B时,页面B都会重新加载并获取最新的数据。这样就能解决页面跳转后未更新的问题。 #### 引用[.reference_title] - *1* *2* [uniapp 页面跳转方法](https://blog.csdn.net/weixin_46167462/article/details/130624717)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [uniapp页面跳转不刷新问题](https://blog.csdn.net/weixin_51411364/article/details/129788886)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值