由于您没有使用vue-router
,我认为您将无法访问参数。因此,您唯一的机会是使用URL API,如下:
const url = new URL(window.location.href);
const getParam = url.searchParams.get('foo');
这将会给你在?foo=bar
中的foo的值。
或者,你可以像这样做。
new Vue({
el: '#app',
data () {
return {
params: window.location.href.substr(window.location.href.indexOf('?'))
}
},
methods: {
getParam (p) {
let param = new URLSearchParams(this.params);
if(param.has(p)){
return param.get(p)
}else{
false
}
}
},
})
getParam('foo')
获取参数即可。你可以使用 window.location.search 获取 URL 参数:
const queryString = window.location.search;
console.log(queryString);
// ?product=troussers&color=black&newuser&size=s
如果要解析查询字符串的参数,请使用URLSearchParams:
const urlParams = new URLSearchParams(queryString);
获取更多信息,请阅读此教程。
目前我们也没有使用Vue Router。我们使用以下脚本来解析参数。
var args = {};
var argString = window.location.hash;
//everything after src belongs as part of the url, not to be parsed
var argsAndSrc = argString.split(/src=/);
args["src"] = argsAndSrc[1];
//everything before src is args for this page.
var argArray = argsAndSrc[0].split("?");
for (var i = 0; i < argArray.length; i++) {
var nameVal = argArray[i].split("=");
//strip the hash
if (i == 0) {
var name = nameVal[0];
nameVal[0] = name.slice(1);
}
args[nameVal[0]] = decodeURI(nameVal[1]);
}
路由属性存在于this.$route
中。
this.$router
是路由器对象的实例,它提供了路由器的配置信息。
您可以使用this.$route.query
获取当前路由查询。