JavaScript之页面url参数获取

从事web开发,总是缺少不了页面之间的交互,在这个过程中核心是页面 url 参数的传递。那要怎样获取页面中 url 具体的参数呢?
首先我们先要了解一下 url 的组成,以 http://www.jianshu.com/c/bd38bd199ec6?utm_medium=index-collections&utm_source=desktop#name 为例说明。

·protocol 协议:通常是http 协议,本例子显示为:“http”;
·host 主机地址:可以是地址,也可以是ip 地址,本例子显示为:“www.jianshu.com”;
·port 端口:http 默认端口是:80端口,本例子显示为:80端口;
·pathname 路径:网络资源在服务器中的指定路径,本例子显示:“/c/bd38bd199ec6”;
·search参数:一般是“?”字符后的字符串,本例子显示为:“?utm_medium=index-collections&utm_source=desktop”;
·hash 锚点:一般是“#”后的字符串,指网页中的片段,设置锚点可以直接到达页面指定的位置,本例子显示为:“#name”。

下面我们来展示一下获取页面 url 具体参数的方法:
1、设置或获取整个url: window.location.href

var test = window.location.href;
alert(test);  // http://www.jianshu.com/c/bd38bd199ec6?utm_medium=index-collections&utm_source=desktop#name

2、设置或获取 url 的 protocol 协议部分:window.location.protocol

var test = window.location.protocol;
alert(test);  // http

3、设置或获取 url 的主机名:window.location.host

var test = window.location.post;
alert(test);  // www.jianshu.com

4、设置或获取 url 的端口:window.location.port

var test = window.location.port;
alert(test);  //空字符(如果采用默认的80端口(update:即使添加了:80),那么返回值并不是默认的80而是空字符)

5、设置或获取 url 的路径:window.location.pathname

var test = window.location.pathname;
alert(test);  //  /c/bd38bd199ec6

6、设置或获取 url 的参数:window.location.search

var test = window.location.search;
alert(test);  //  ?utm_medium=index-collections&utm_source=desktop

7、设置或获取 页面的锚点:window.location.hash

var test = window.location.hash;
alert(test);  //  #name

8、JavaScript 获取 url 中的参数
(1)、正则方法

function getQueryString(name) {
  var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');  //设置正则匹配规范
  var r = window.location.search.substr(1).match(reg);  // 获取“?”后的字符串并正则匹配
  if (r != null) {
    return decodeURIComponent(r[2]); // 解码参数部分
  }
  return null;
}

(2)、split拆分法

function getRequest() {
  var url = window.location.search; 
  var theRequest = new Object();
  if(url.indexof != -1) { //判断是否有参数
    var str = url.substr(1);  //从第一个字符开始 因为第0个是?号 获取所有除问号的所有符串
    strs = str.split("&");  //截除“&”生成一个数组
    var i = 0, len = strs.length;
    for(i = 0; i < len; i++) {
      theRequest[strs[i].split("=")[0]] = decodeURIComponent(strs[i].split("=")[1]);  
    }
  }
  console.log(theRequest);
}
getRequest(); // {utm_medium: "index-collections", utm_source: "desktop"}

(3)获取指定参数的值

function getQueryString(name) {
  var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
  var r = window.location.search.substr(1).match(reg);
  var context = '';
  if (r != null) {
    context = r[2];
  }
  reg = null; 
  r = null; 
  return context == null || context == "" || context == "undefined" ? "" : context; 
}
getQueryString("utm_medium");  // "index-collections"

(4)、单个参数的获取

function GetRequest() {
  var url = location.search; 
  if (url.indexOf("?") != -1) {  
   var str = url.substr(1); 
   strs = str.split("=");  
   console.log(strs[1]);     
  }
}
GetRequest(); // index-collections&utm_source

戳我博客

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,064评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,606评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,011评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,550评论 1 269
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,465评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,919评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,428评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,075评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,208评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,185评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,191评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,914评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,482评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,585评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,825评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,194评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,703评论 2 339

推荐阅读更多精彩内容