美文网首页
在路由中截取网址参数

在路由中截取网址参数

作者: 君临12138 | 来源:发表于2018-11-26 16:13 被阅读0次

    1.vuejs取得URL中参数的值

    1.http://localhost:3333/#/index?id=001
    console.log(this.$route.query.id) //结果 001
    
    2.// vue首页直接匹配
    getUrlKey (name) {
      if (new RegExp('[?|&]' + name + '=' + '([^&;]+?)(&|#|;|$)').exec(location.href)) {
        return decodeURIComponent((new RegExp('[?|&]' + name + '=' + '([^&;]+?)(&|#|;|$)').exec(location.href) || [''])[1].replace(/\+/g, '%20')) || null
      }
    },
    

    2. js获取URL中的参数

    js获取URL中的一些参数的意思
    location对象 含有当前URL的信息. 属性 href 整个URL字符串.
    protocol 含有URL第一部分的字符串,如http:
    host 包含有URL中主机名:端口号部分的字符串.如//www.cenpok.net/server/
    hostname 包含URL中主机名的字符串.如http://www.cenpok.net ;
    port 包含URL中可能存在的端口号字符串.
    pathname URL中"/"以后的部分.如~list/index.htm
    hash "#"号(CGI参数)之后的字符串.
    search "?"号(CGI参数)之后的字符串.
    1.第一种:只适用于/User/vip_card_manager?useless=219

    function UrlSearch() {
       var name,value;
       var str=location.href; //取得整个地址栏
       var num=str.indexOf("?")
       str=str.substr(num+1); //取得所有参数   stringvar.substr(start [, length ]
    
       var arr=str.split("&"); //各个参数放到数组里
        console.log(arr)
       for(var i=0;i < arr.length;i++){
            num=arr[i].indexOf("=");
            if(num>0){
                 name=arr[i].substring(0,num);
                 value=arr[i].substr(num+1);
                 this[name]=value;
            }
       }
    }
    

    2.第二种:
    适应以下两种模式,来获取url参数值:
    /User/vip_card_manager/useless/219/id/18
    /User/vip_card_manager?useless=219&id=18

    console.log(getQueryString("useless"));
    function getQueryString(name) {
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
        var reg_rewrite = new RegExp("(^|/)" + name + "/([^/]*)(/|$)", "i");
        var r = window.location.search.substr(1).match(reg);
        var q = window.location.pathname.substr(1).match(reg_rewrite);
        if(r != null){
            return unescape(r[2]);
        }else if(q != null){
            return unescape(q[2]);
        }else{
            return null;
        }
    }
    

    3.第三种:

    /**
     * 获取指定的URL参数值
     * URL:http://www.quwan.com/index?name=tyler
     * 参数:paramName URL参数
     * 调用方法:getParam("name")
     * 返回值:tyler
     */
    function getParam(paramName) {
        paramValue = "", isFound = !1;
        if (this.location.search.indexOf("?") == 0 && this.location.search.indexOf("=") > 1) {
            arrSource = unescape(this.location.search).substring(1, this.location.search.length).split("&"), i = 0;
            while (i < arrSource.length && !isFound) arrSource[i].indexOf("=") > 0 && arrSource[i].split("=")[0].toLowerCase() == paramName.toLowerCase() && (paramValue = arrSource[i].split("=")[1], isFound = !0), i++
        }
        return paramValue == "" && (paramValue = null), paramValue
    }
    

    相关文章

      网友评论

          本文标题:在路由中截取网址参数

          本文链接:https://www.haomeiwen.com/subject/cxvbqqtx.html