Javascript - HTML的request类
做中英转换的时候,要准确的获取参数并取出,所以做了一个简单的html中用js获取当取地址栏的一个Object。 里面有三个方法: 1、request.QueryString("参数")//获取指定参数,返回字符串; 2、request.QueryStrings();//获取全部参数,并返回数组; 3、request.setQuery("参数","参数的值");//如果当前地址栏有此参数,那么将更新此参数,否则返回一个新的地址栏参数字符串。 例如: 当前地址栏参数字符串为:?name=a&site=never_online alert(request.setQuery("name","blueDestiny")) 如果地址栏参数中有"name",那么返回?name=blueDestiny&site=never_online setQuery方法有自动追加参数的功能。如: 当前地址栏参数字符串为:?site=never_online alert(request.setQuery("name","blueDestiny")) 则返回?site=never_online&name=blueDestiny 同理,如果地址栏没有参数,也会自动追加参数 alert(request.setQuery("name","blueDestiny")) 返回?name=blueDestiny <SCRIPT LANGUAGE="JavaScript"> <!-- // author: never-online // web: never-online.net var request = { QueryString : function(val) { var uri = window.location.search; var re = new RegExp("" +val+ "\=([^\&\?]*)", "ig"); return ((uri.match(re))?(uri.match(re)[0].substr(val.length+1)):null); }, QueryStrings : function() { var uri = window.location.search; var re = /\w*\=([^\&\?]*)/ig; var retval=[]; while ((arr = re.exec(uri)) != null) retval.push(arr[0]); return retval; }, setQuery : function(val1, val2) { var a = this.QueryStrings(); var retval = ""; var seted = false; var re = new RegExp("^" +val1+ "\=([^\&\?]*)$", "ig"); for(var i=0; i<a.length; i++) { if (re.test(a[i])) { seted = true; a[i] = val1 +"="+ val2; } } retval = a.join("&"); return "?" +retval+ (seted ? "" : (retval ? "&" : "") +val1+ "=" +val2); } } alert(request.setQuery("e","b")) //--> </SCRIPT>
相关推荐
nmgxzm00 2020-11-10
ifconfig 2020-10-14
hhanbj 2020-11-17
zfszhangyuan 2020-11-16
古叶峰 2020-11-16
一个智障 2020-11-15
jipengx 2020-11-12
81427005 2020-11-11
xixixi 2020-11-11
游走的豚鼠君 2020-11-10
苗疆三刀的随手记 2020-11-10
Web卓不凡 2020-11-03
小飞侠V 2020-11-02
帕尼尼 2020-10-30
爱读书的旅行者 2020-10-26
帕尼尼 2020-10-23
杏仁技术站 2020-10-23
淼寒儿 2020-10-22