Object.keys()、Object.values()
时间: 2023-10-12 14:19:51 浏览: 91
Object.keys() 方法返回一个给定对象自身可枚举属性的键名数组,而 Object.values() 方法返回一个给定对象自身可枚举属性的键值数组。
例如,假设我们有以下对象:
```javascript
const obj = {
name: 'Alice',
age: 25,
gender: 'female'
};
```
我们可以使用 Object.keys() 方法获取 obj 对象的所有键名:
```javascript
const keys = Object.keys(obj);
console.log(keys); // ['name', 'age', 'gender']
```
同样地,我们可以使用 Object.values() 方法获取 obj 对象的所有键值:
```javascript
const values = Object.values(obj);
console.log(values); // ['Alice', 25, 'female']
```
需要注意的是,Object.keys() 和 Object.values() 方法只会返回对象自身的可枚举属性,不会返回其原型链上的属性。如果需要获取所有属性,可以使用 Object.getOwnPropertyNames() 方法。
相关问题
对象的常用的操作 Object.assign(对象的深复制/浅复制) Object.defineProperty Object.keys Object.values Object.freeze
在中国的JavaScript中,这几个都是关于对象操作的重要工具:
1. `Object.assign()`:这是一个用于合并多个对象到一个新的对象中的方法。它不会创建新的引用,而是将源对象的属性浅复制到目标对象中,如果目标对象已有同名属性,则会被覆盖。例如:
```
const obj1 = { a: 1 };
const obj2 = { b: 2 };
const newObj = Object.assign(obj1, obj2);
// newObj: {a: 1, b: 2}
```
2. `Object.defineProperty()`:这个方法允许你在运行时修改对象的特性(如添加、删除或修改属性的访问器、可枚举性、可配置性和值)。这对于动态控制属性很有帮助。
3. `Object.keys()` 和 `Object.values()` 分别用于获取对象的所有键名和键对应的值(属性值)以数组形式返回。例如:
```
const obj = { a: 1, b: 2 };
const keys = Object.keys(obj); // ["a", "b"]
const values = Object.values(obj); // [1, 2]
```
4. `Object.freeze()`:此方法用于锁定对象,使其不可添加新属性、删除现有属性或改变其自身和原型链上的任何属性。一旦对象被冻结,所有试图修改的行为都会被阻止。
Object.keys Object.values IE兼容
在JavaScript中,`Object.keys()` 和 `Object.values()` 都是用于遍历对象的方法,分别返回对象自身的所有可枚举属性名(keys)和值(values)。这两个方法在现代浏览器(如Chrome、Firefox、Safari等)以及Node.js环境中非常常用。
- `Object.keys(obj)`:接收一个对象作为参数,返回一个数组,包含该对象的所有自身可枚举属性的名称,数组按照属性名的顺序排列。
- `Object.values(obj)`:同样接收一个对象,返回一个数组,包含该对象的所有自身可枚举属性的值,数组也是按照属性顺序排列。
然而,在旧版的Internet Explorer (IE)中,特别是版本低于9,对ES5标准的支持不足,`Object.keys` 和 `Object.values` 可能并不直接可用。开发者通常需要引入polyfill(即浏览器不支持的特性补充),或者使用其他方式来实现类似功能,比如通过`for...in`循环手动获取键或值。
为了保证在IE中的兼容性,你可以这样做:
```javascript
if (!Object.keys) {
Object.keys = function(obj) {
// 使用其他方法模拟原生keys的行为...
};
}
if (!Object.values) {
Object.values = function(obj) {
var keys = Object.keys(obj);
return keys.map(function(key) { return obj[key]; });
};
}
```
阅读全文