这是之前在网上找的一个HTML页面获取链接后面的参数的例子,本人觉得写的很好,一直在用,下面粘贴上js源码:
var LocString=String(window.document.location.href);
function GetQueryString(str){
var rs=new RegExp("(^|)"+str+"=([^&]*)(&|$)","gi").exec(LocString),tmp;
if(tmp=rs)return tmp[2];
return "没有这个参数";
}
alert("日记名称:"+GetQueryString("name"));
alert("分类编号:"+GetQueryString("hehe"));
alert("所在页数:"+GetQueryString("hh"));
相信大家一看就懂了,但是这里面还涉及到一个问题就是如果链接中存在中文的话,会自动被转码。
取中文参数需要解码,比如上面的日记名称如果是中文的话:
var name= decodeURI(GetQueryString("name"));
alert("日记名称:"+name);
这样alert的值才是中文的。顺便普及两个知识点,上面说的链接中的中文会被自动编码。其实我们也可以自己手动进行编码,防止在中文数据在传输变乱码。
这里就涉及到java和js的两种转码方式,其实用的方法都是一样的。
Java方法:
java.net.URLDecoder.decode(URIString, "UTF-8"); //按照utf-8进行解码
java.net.URLEncoder.encode(URIString, "UTF-8"); //按照utf-8进行编码
js方法
decodeURI() //解码
encodeURI() //编码
这里encodeURI()方法的结果和链接里面自动编码的结果是一样的。