javascript - [,null]是什么用法
问题描述
看到用下面的函数来取得url的值。
function getURLParameter(name) { return decodeURI((RegExp(name + ’=’ + ’(.+?)(&|$)’).exec(location.search)||[,null])[1] );}
但是不知道[,null]在这里是什么表达方式。
问题解答
回答1:这个函数的作用是想取得URI中某个参数的值,如网址http://www.xxx.com/index.html?key=hello&value=world*,此时的location.search等于?key=hello&value=world。比如要获取key的值('hello'),调用getURLParameter('key')就行。
exec的语法如下:
如果匹配,则返回结果是一个数组,数组的第一个元素是匹配的子串,后面的元素则依次是捕获型括号的内容,由正则表达式可见,我们需要的结果是第一个捕获型括号的内容,是数组的第二个元素,所以使用了[1];
举例来说,假设网址还是上面的网址,我们调用getURLParameter('key'),匹配的结果是['key=hello&', 'hello', '&'],'key=hello&'是匹配的子串,'hello'是第一个捕获型括号的内容,'&'是第二个捕获型括号的内容。['key=hello&', 'hello', '&'] || [,null]的结果当然是前一项,也就是['key=hello&', 'hello', '&'], 然后取[1],整个函数的返回值就是'hello'。
但是,如果我们调用getURLParameter('time'),匹配失败,所以结果是null,此时如果你调用[1]就会报错。[,null]表示[undefined, null],当匹配失败的时候,就变成了null || [undefined, null]这个结果是[undefined, null],此时再[1]就不会报错了,此时整个函数返回的是null。
调用完getURLParameter函数以后,可以通过判断返回值是否是null,如果是null,则说明URL中没有这个参数;不为null,则返回值就是需要的参数值。
回答2:偷懒的做法,(name + ’=’ + ’(.+?)(&|$)’).exec(location.search)如果匹配成功。结果不会null。(.+?)就是正则匹配的值[1]。而如果匹配失败,exec返回null。[,null]第一个值为undefined,这个操作只是统一了返回值为null,关键还是最后面的[1]导致的如果后面的是[0],那[,null]可以改写为[null]
回答3:[,null][1]不就是null了吗,前面的匹配不到就返回null
回答4:相当于这样吧
return decodeURI( ( RegExp(name + ’=’ + ’(.+?)(&|$)’).exec(location.search) )[1] || null);
但是前面( RegExp(name + ’=’ + ’(.+?)(&|$)’).exec(location.search) )这一段如果没有获取到参数值,直接取[1]会报错,所以在后面加[,null],相当于[undefined, null],在最后取[1],可以确保不会因为获取不到url参数而发生数组越界错误
相关文章:
1. javascript - [多图预警]reactjs点击某表格编辑内容,跳转传值this.context.router.params.id时id报错未定义2. javascript - [CSS + JS]如何使用JS代码获得 元素计算后的全部样式 并 对应值??3. javascript - [React Native]如何在Tabs内维护每一个ListView的滚动条?4. javascript - [WDS] Disconnected! 一直重复出现。5. javascript - [js]为什么画布里不出现图片呢?在线等6. javascript - [CSS] css能否实现img 高与宽 相等 ?7. javascript - [MUI 子webview定位]
