ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript の Object のさまざまなメソッドの概要 (例付き)

JavaScript の Object のさまざまなメソッドの概要 (例付き)

不言
不言転載
2019-01-29 09:42:212405ブラウズ

この記事は、JavaScript のオブジェクトのさまざまなメソッドをまとめたものです (例付き)。必要な方は参考にしていただければ幸いです。

1. hasOwnProperty

obj.hasOwnProperty(prop)

Parameters

prop: 検出する属性文字列名、またはシンボル

戻り値

オブジェクトに指定されたプロパティが含まれているかどうかを判断するために使用されるブール値

Object を継承するすべてのオブジェクトは hasOwnProperty() メソッドを継承します。このメソッドは、オブジェクトに独自の特定のプロパティが含まれているかどうかを検出するために使用されます。 in 演算子とは異なり、このメソッドはプロトタイプ チェーンから継承されたプロパティを無視します

Object.prototype.a = 'aaa';
var obj = {
  b: 'bbb'
}
console.log(obj.hasOwnProperty(a)); // false
for(var item in obj) {
  console.log(item); // b  a。此结果也找到了从原型链上继承过来的属性
}

hasOwnProperty がプロパティ名として使用される場合

var foo = {
  hasOwnProperty: function() {
    return false
  },
  bar: 'bar'
}

foo.hasOwnProperty('bar'); // false
// 如果这种情况下,想调用原型链上的方法
({}).hasOwnProperty.call(foo, 'bar'); // 即foo对象调用了{}对象的方法。
// 等同于
Object.prototype.hasOwnProperty.call(foo, 'bar')

拡張: オブジェクトのすべてのプロパティを走査

# for ... in は列挙可能なプロパティのみをループするため、これに基づいて列挙不可能なプロパティをループしないでください。

2.getOwnPropertyNames

Object.getOwnPropertyNames(obj)
Parameters

obj 独自の列挙可能および列挙不可能なプロパティを持つオブジェクト 名前が返されます。

戻り値

指定されたオブジェクトで見つかった独自のプロパティに対応する文字列配列。

Object.getOwnPropertyNames() は、obj 内の列挙可能プロパティと列挙不可能なプロパティを含む配列を返します。
3.Object.keys()

Object.keys(obj)
Parameters

独自のプロパティを列挙するオブジェクトを返すには

戻り値

指定されたオブジェクトの列挙可能なすべてのプロパティを表す文字列配列

説明

Object.keys() は、要素が文字である文字列配列を返します。要素が指定されたオブジェクトの列挙可能なプロパティから直接取得される文字列。これらのプロパティの順序は、プロパティを手動で走査する場合と一致します (...in...)。

var obj = {a:'a',b:'b',c:'c'};
console.log(Object.keys(obj));// ['a', 'b', 'c']
4.Object.values()

Object.keys() はキー値を返し、Object.values() は値値を返します。ルールは Object.keys( と同じです) )。

5.Object.assign()

Object.assign() は、すべての列挙可能な値を 1 つのオブジェクトからターゲット オブジェクトにコピーするために使用されます。ターゲットオブジェクトを返します。

Object.assign(target, ...sources);
Description

ターゲット オブジェクトのプロパティがソース オブジェクトのプロパティと同じプロパティを持つ場合。ターゲット オブジェクトのプロパティは上書きされます。 String型とSymbol型のプロパティがコピーされます。

エラーの場合、たとえばプロパティが書き込み可能でない場合、TypeError が発生し、エラーが発生する前にプロパティが追加されていた場合、ターゲット オブジェクトは変更される可能性があります。

const a = {a: 'a', b: 'b'};
var b = Object.assign({}, a);
console.log(b); //{a: 'a', b: 'b'}
ディープコピー、Object.assign() はオブジェクトの最初のレイヤーのプロパティのみをコピーできます。ソース オブジェクトのプロパティ値がオブジェクトへの参照である場合、その参照値のみがコピーされます。

  let obj1 = { a: 0 , b: { c: 0}};
  let obj2 = Object.assign({}, obj1);
  console.log(JSON.stringify(obj2)); // { a: 0, b: { c: 0}}
  
  obj1.a = 1;
  console.log(JSON.stringify(obj1)); // { a: 1, b: { c: 0}}
  console.log(JSON.stringify(obj2)); // { a: 0, b: { c: 0}}
  
  obj2.a = 2;
  console.log(JSON.stringify(obj1)); // { a: 1, b: { c: 0}}
  console.log(JSON.stringify(obj2)); // { a: 2, b: { c: 0}}
  
  obj2.b.c = 3;
  console.log(JSON.stringify(obj1)); // { a: 1, b: { c: 3}}
  console.log(JSON.stringify(obj2)); // { a: 2, b: { c: 3}}
  
  // Deep Clone
  obj1 = { a: 0 , b: { c: 0}};
  let obj3 = JSON.parse(JSON.stringify(obj1));
  obj1.a = 4;
  obj1.b.c = 4;
  console.log(JSON.stringify(obj3)); // { a: 0, b: { c: 0}}
オブジェクトをマージ

var o1 = { a: 1 };
var o2 = { b: 2 };
var o3 = { c: 3 };

var obj = Object.assign(o1, o2, o3);
console.log(obj); // { a: 1, b: 2, c: 3 }
console.log(o1);  // { a: 1, b: 2, c: 3 }, 注意目标对象自身也会改变。
同じプロパティを持つオブジェクトをマージすると、そのプロパティは後続のパラメータ内の同じプロパティを持つ他のオブジェクトによって上書きされます。

var o1 = { a: 1, b: 1, c: 1 };
var o2 = { b: 2, c: 2 };
var o3 = { c: 3 };

var obj = Object.assign({}, o1, o2, o3);
console.log(obj); // { a: 1, b: 2, c: 3 }
シンボル型の属性をコピー

var o1 = { a: 1 };
var o2 = { [Symbol('foo')]: 2 };

var obj = Object.assign({}, o1, o2);
console.log(obj); // { a : 1, [Symbol("foo")]: 2 } (cf. bug 1207182 on Firefox)
Object.getOwnPropertySymbols(obj); // [Symbol(foo)]
継承されたプロパティと列挙不可能なプロパティはコピーできません

var obj = Object.create({foo: 1}, { // foo 是个继承属性。
    bar: {
        value: 2  // bar 是个不可枚举属性。
    },
    baz: {
        value: 3,
        enumerable: true  // baz 是个自身可枚举属性。
    }
});

var copy = Object.assign({}, obj);
console.log(copy); // { baz: 3 }
元の型はオブジェクトとしてパッケージ化されます

var v1 = "abc";
var v2 = true;
var v3 = 10;
var v4 = Symbol("foo")

var obj = Object.assign({}, v1, null, v2, undefined, v3, v4); 
// 原始类型会被包装,null 和 undefined 会被忽略。
// 注意,只有字符串的包装对象才可能有自身可枚举属性。
console.log(obj); // { "0": "a", "1": "b", "2": "c" }
例外により後続のコピー タスクが中断されます

var target = Object.defineProperty({}, "foo", {
    value: 1,
    writable: false
}); // target 的 foo 属性是个只读属性。

Object.assign(target, {bar: 2}, {foo2: 3, foo: 3, foo3: 3}, {baz: 4});
// TypeError: "foo" is read-only
// 注意这个异常是在拷贝第二个源对象的第二个属性时发生的。

console.log(target.bar);  // 2,说明第一个源对象拷贝成功了。
console.log(target.foo2); // 3,说明第二个源对象的第一个属性也拷贝成功了。
console.log(target.foo);  // 1,只读属性不能被覆盖,所以第二个源对象的第二个属性拷贝失败了。
console.log(target.foo3); // undefined,异常之后 assign 方法就退出了,第三个属性是不会被拷贝到的。
console.log(target.baz);  // undefined,第三个源对象更是不会被拷贝到的。
コピー アクセサ

var obj = {
  foo: 1,
  get bar() {
    return 2;
  }
};

var copy = Object.assign({}, obj); 
// { foo: 1, bar: 2 }
// copy.bar的值来自obj.bar的getter函数的返回值 
console.log(copy); 

// 下面这个函数会拷贝所有自有属性的属性描述符
function completeAssign(target, ...sources) {
  sources.forEach(source => {
    let descriptors = Object.keys(source).reduce((descriptors, key) => {
      descriptors[key] = Object.getOwnPropertyDescriptor(source, key);
      return descriptors;
    }, {});

    // Object.assign 默认也会拷贝可枚举的Symbols
    Object.getOwnPropertySymbols(source).forEach(sym => {
      let descriptor = Object.getOwnPropertyDescriptor(source, sym);
      if (descriptor.enumerable) {
        descriptors[sym] = descriptor;
      }
    });
    Object.defineProperties(target, descriptors);
  });
  return target;
}

var copy = completeAssign({}, obj);
console.log(copy);
// { foo:1, get bar() { return 2 } }

以上がJavaScript の Object のさまざまなメソッドの概要 (例付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はsegmentfault.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。