平时在写js的时候遇到多层属性嵌套,一般大家敢直接用点使用吗?
有没有开发的时候好好的,某一时刻突然出现一个控制台报错类似:Uncaught TypeError: xxx is not a function
一般这种情况就是没有判断是否有值,如果数据是后端返回的,有可能后端就是没有值或者值的类型不对,这些情况都可能导致出现程序出错,一般我们需要进行判断,常见的判断就是
JavaScript代码
- if(obj.a && obj.a.b && obj.a.b.c && obj.a.b.c.d){
- // do something
- }
JavaScript代码
- function checkNested(obj /*, level1, level2, ... levelN*/) {
- var args = Array.prototype.slice.call(arguments),
- obj = args.shift();
- for (var i = 0; i < args.length; i++) {
- if (!obj || !obj.hasOwnProperty(args[i])) {
- return false;
- }
- obj = obj[args[i]];
- }
- return true;
- }
- var test = {level1:{level2:{level3:'level3'}} };
- checkNested(test, 'level1', 'level2', 'level3'); // true
- checkNested(test, 'level1', 'level2', 'foo'); // false
方法4:
JavaScript代码
- var myURL;
- if (Bro(app).doYouEven('config.environment.buildURL')) {
- myURL = app.config.environment.buildURL('dev');
- }
方法5:
JavaScript代码
- var object = { 'a': [{ 'b': { 'c': 3 } }] };
- _.get(object, 'a[0].b.c');
- // => 3
- _.get(object, ['a', '0', 'b', 'c']);
- // => 3
- _.get(object, 'a.b.c', 'default');
- // => 'default'