antd2.0.1
里的Cascorder
这个组件,它的defaultValue
不起做用,是一个bug。当我发现这是一个bug的时候,应该想着如何去避免这个bug,好比使用value
, 而不是告诉别人这是个bug。要学会本身解决问题!!!Object.entries()
方法返回给定对象本身的枚举属性[key, value]
对的数组。其顺序和与for...in
循环提供的顺序相通,区别在于for...in
循环枚举原型中的属性。es6
下面看例子:数据库
const Person = { name: 'yuzf', age: '18', gender: 'man', }; // [['name': 'yuzf'], ['age': 18], ['gender', 'man']] console.log(Object.entries(Person)); const result = {}; // 数组解构/for of 循环 for (const [key, value] of Object.entries(Person)) { // good result[key] = value; // bad // result.key = value; }
Object.keys()
返回一个数组,其元素是对应于直接在对象上发现的可枚举属性的字符串(即不包含原型链上的)。属性的顺序与经过手动循环对象的属性给出的顺序相同。数组
下面直接看代码说明:antd
const arr1 = ['a', 'b', 'c']; console.log(Object.keys(arr1)); // ['0', '1', '2'] const person = { name: 'yuzf', age: 18, gender: 'man', }; for (const key of Object.keys(person)) { console.log(key); // name, age, gender }
Object.getOwnPropertyNames()
方法返回一个直接发现给定对象的全部属性(可枚举和不可枚举)的数组。测试
下面看代码例子:ui
const arr = ['a', 'b', 'c']; console.log(Object.getOwnPropertyNames(arr).sort); // logs: ['0', '1', '2', 'length'] const arr2 = { name: 'yuzf', age: 18, gender: 'man', }; console.log(Object.getOwnPropertyNames(arr).sort); // logs: ['name', 'age', 'gender']
以前,我也遇到这样的需求, 将一个数组里包含的多个对象转成一个对象,结构像下面这个样子:this
// origin const Person = [ { name: 'yuzf'}, { age: 18 }, { gender: 'man' }, ]; // to => this { name: 'yuzf', age: 18, gender: 'man', } // do const obj = Person.reduce((x, y) => Object.assign({}, x, y), {})
Do not access Object.prototype method 'hasOwnProperty' from target object no-prototype-builtins
, 大概的意思是不要使用对象原型上的方法,由于原型上的方法可能被重写了。This is why。prototype
那么该如何避免这个问题呢?下面请看代码:eslint
// bad if (obj.hasOwnProperty('name')) { } // good if (Object.prototype.hasOwnProperty.call(obj, 'name')) { }
多是本身代码写着写着就将本身写懵了,fields.concat(['xx'])
, 这行代码执行后, 怎么fields的值没有变化。code
这真是一件很傻的事情。
mdn: Object.entries()
mdn: Object.keys()
mdn: Object.getOwnPropertyNames()