利用js进行页面跳转及传递参数的获取

页面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数组写在了$(function() { })里面,所以要想获得这个数组的值,那么你的代码就得继续写在这个$(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);	
});

 

你可能感兴趣的:(web应用程序)