可能重复:
JavaScript 查询字符串
我想访问附加到我的脚本 url 的查询变量。例如:
<script type="text/javascript" src="http://mysite.com/app.js?var1=value1&var2=value2"></script>
在 app.js 中,如何访问 var1 和 var2 值?
可能重复:
JavaScript 查询字符串
我想访问附加到我的脚本 url 的查询变量。例如:
<script type="text/javascript" src="http://mysite.com/app.js?var1=value1&var2=value2"></script>
在 app.js 中,如何访问 var1 和 var2 值?
此页面描述了获取这些值的方法:
<script type="text/javascript"
src="scriptaculous.js?load=effects,builder"></script>
和javascript:
function getJSvars(script_name, var_name, if_empty) {
var script_elements = document.getElementsByTagName(‘script’);
if(if_empty == null) {
var if_empty = ”;
}
for (a = 0; a < script_elements.length; a++) {
var source_string = script_elements[a].src;
if(source_string.indexOf(script_name)>=0) {
var_name = var_name.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]");
var regex_string = new RegExp("[\\?&]"+var_name+"=([^&#]*)");
var parsed_vars = regex_string.exec(source_string);
if(parsed_vars == null) { return if_empty; }
else { return parsed_vars[1]; }
}
}
}
解析src
属性,大致如下:
var src=document.getELementById("script-id").getAttribute("src");
var query=src.substring(src.indexOf("?"));
var query_vals=query.split("&");
var queries={};
for (var i=0;i<query_vals.length;i++) {
var name_val=query_vals.split("=");
queries[name_val[0]]=name_val[1];
}
console.log(queries.var1, queries.var2);
但是,有一些库,例如 url.js,可以更好地执行此操作,并且在 URL 编码等方面更加健壮。