ES6 객체의 확장 및 새로운 메소드 요약(예제 포함)
이 기사는 ES6 객체의 확장 및 새로운 방법에 대한 요약을 제공합니다(예제 포함). 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
1. 속성의 간결한 표현
ES6에서는 변수와 함수를 객체의 속성과 메서드로 직접 작성할 수 있습니다. 이런 종류의 글은 더 간결합니다.
const foo = 'bar'; const baz = {foo}; baz//{foo:'bar'} //等同于 const baz = {foo:foo}
위 코드는 ES6에서 변수를 객체에 직접 작성할 수 있음을 보여줍니다. 이때 속성명은 변수명, 속성값은 변수의 값이 된다. 또 다른 예가 있습니다.
function f(x,y){ return {x,y} } //等同于 function f(x,y){ return {x:x,y:y}; } f(1,2)//{x:1,y:2}
속성 약어 외에도 메소드도 약어화할 수 있습니다.
const o ={ method(){ return 'Hello!' } } //等同于 const o = { method:function(){ return 'Hellow'; } }
다음은 실제적인 예입니다.
let birth = '2000/01/01'; const Person ={ name:'张三', //等同于birth:birth birth, //等同于hello :function().... hello(){ console.log('我的名字是',this.name) } }
이러한 작성 방법은 함수의 반환 값에 매우 편리합니다.
function getPoint(){ const x =1; const y = 10; return {x,y} } getPoint()//{x:1,y:10}
CommonJS 모듈은 변수 세트를 출력하므로 간결한 글쓰기에 매우 적합합니다.
let ms = {}; function getItem(key){ return key in ms ?ms[key]:null; } function setItem(key,value){ ms[key] = value; } function clear(){ ms={} } module.exports = {getItem,setItem,clear}; //等同于 module.exports = { getItem:getItem, setItem:setItem, clearLclear }
속성의 setter와 getter는 실제로 이런 식으로 작성됩니다.
const cart = { _wheels:4, get wheels(){ return this._wheels; }, set wheels (value){ if(value<this._wheels){ throw new Error('数值太小了!'); } this._whells = value; } }
2. 속성 이름 표현
JavaScript에서 객체의 속성을 정의하는 방법에는 두 가지가 있습니다.
//方法一 obj.foo = true; //方法二 obj['a'+'bc'] = 123;
위 코드의 첫 번째 방법은 식별자를 속성 이름으로 직접 사용하는 것이고, 두 번째 방법은 표현식을 속성 이름으로 사용하는 것입니다. 이 경우 표현식을 대괄호 안에 넣으세요.
그러나 리터럴을 사용하여 객체를 정의하는 경우(중괄호 사용) ES5에서 속성을 정의하는 데 방법 1(식별자)만 사용할 수 있습니다.
var obj ={ foo:true, abc:123 }
ES6에서는 객체를 정의할 때 리터럴을 사용할 수 있습니다. 방법 2는 객체의 속성 이름으로 사용됩니다. 즉, 표현식이 괄호 안에 배치됩니다.
let propKey = 'foo'; let obj ={ [propKey]:true, ['a'+'bc']:123 }
여기 또 다른 예가 있습니다:
let lastWord = 'last word'; const a = { 'first word':'hello', [lastWord]:'world' }; a['first word']//hello a[lastWord]//world a['last word']//world
표현식은 메소드 이름을 정의하는 데에도 사용될 수 있습니다.
let obj = { ['h'+'ello'](){ return 'hi' } } obj.hello()//hi;
참고:
属性名表达式与简洁表示法,不能同时使用,会报错。 属性名表达式如果是一个对象,默认情况下会自动将对象转为字符串[object object],这一点要特别小心。
const keyA = {a:1}; const keyB = {b:2}; const myObject = { [keyA]:'valueA', [keyB]:'valueB' }; myObject;// Object {[object Object]: "valueB"}
위 코드에서 [keyA] 및 [keyB]는 [객체 객체]를 모두 가져오므로 [keyB]는 [keyA]를 덮어쓰고 myObject는 끝에 하나의 [객체 객체] 속성만 갖습니다. .
메서드의 name 속성
함수의 name 속성은 함수 이름을 반환합니다. 객체 메서드도 함수이므로 name 속성도 갖습니다.
const person = { sayName() { console.log('hello!'); }, }; person.sayName.name // "sayName"
속성의 열거 가능한 유형 및 탐색
객체의 각 속성에는 속성 변경 동작을 제어하는 데 사용되는 설명 객체가 있습니다. Object.getOwnPropertyDescriptor(obj,'foo') 메소드는 속성의 설명 객체를 얻을 수 있습니다.
열거 가능성이라는 개체의 열거 가능 특성을 설명합니다. 이 특성이 false인 경우 특정 작업이 현재 특성을 무시한다는 의미입니다.
현재 열거 가능 값이 false인 속성을 무시하는 4가지 작업이 있습니다.
for...in循环:只遍历对象自身的和继承的可枚举的属性。(不包含Symbol属性) Object.keys():返回对象自身的所有可枚举的属性的键名,返回一个数组。(不包含Symbol) JSON.stringify():只串行化对象自身的可枚举的属性。 object.assign():忽略enumrable为false的属性,只拷贝对象自身的可枚举的属性。
ES6에는 객체의 속성을 탐색하는 총 5가지 메서드가 있습니다.
(1) for...in
for...in循环遍历对象自身的和继承的可枚举属性(不包含Symbol属性)。
(2) Object.keys(obj)
object.keys返回一个数组,包含对象自身的(不含继承的)所有可枚举属性(不包含Symbol属性)的键名。
(3) Object.getOwnPropertyNames(obj)
返回一个数组,包含对象自身的所有属性(不含Symbol属性,但是包括不可枚举属性)的键名。
(4) Object.getOwnPropertySymbols(obj)
返回一个数组,包含对象自身的所有Symbol属性的键名。
(5 ) Reflect.ownKeys(obj)
Reflect.ownKeys返回一个数组,包含对象自身的所有键名,不管键名是Symbol或字符串,也不管是否可枚举。
super 키워드
우리는 this 키워드가 항상 함수가 있는 현재 객체를 가리킨다는 것을 알고 있으며, ES6에는 현재의 프로토타입 객체를 가리키는 또 다른 유사한 키워드 super를 추가했습니다. 물체.
const proto = { foo:'hello' }; const obj = { foo:'world', find(){ return super.foo; } }; Object.setPrototypeOf(obj,proto); obj.find();//hello
위 코드의 객체 obj.find() 메소드에서 프로토타입 객체 proto의 foo 속성은 super.foo를 통해 참조됩니다.
참고: super 키워드가 프로토타입 객체를 나타내는 경우 해당 객체의 메서드에서만 사용할 수 있습니다. 다른 곳에서 사용하면 오류가 보고됩니다. 현재는 객체 메소드 약어만을 사용하여 Javascript 엔진이 객체 메소드가 정의되었는지 확인할 수 있습니다.
JavaScript 엔진 내에서 super.foo는 Object.getPrototypeOf(this).foo 또는 Object.getPrototypeOf(this).foo.call(this)과 동일합니다.
객체 확산 연산자
구조 분해 할당
객체 분해 할당은 객체에서 값을 가져오는 데 사용됩니다. 이는 탐색 가능하지만 대상 객체 자체의 속성을 아직 읽지 않은 모든 속성을 지정된 객체에 할당하는 것과 같습니다. 모든 키와 해당 값이 새 개체에 복사됩니다.
let{x,y,...z} = {x:1,y:2,a:3,b;4}; x//1, y//2, z//{a:3,b:4}
위 코드에서 변수 z는 구조 분해 할당이 위치한 객체입니다. 등호 오른쪽에 있는 읽지 않은 모든 키(a 및 b)를 가져와 해당 값과 함께 복사합니다.
위 내용은 ES6 객체의 확장 및 새로운 메소드 요약(예제 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.

JavaScript에서 HTTP 상태 코드를 얻는 방법 소개: 프런트 엔드 개발에서 우리는 종종 백엔드 인터페이스와의 상호 작용을 처리해야 하며 HTTP 상태 코드는 매우 중요한 부분입니다. HTTP 상태 코드를 이해하고 얻는 것은 인터페이스에서 반환된 데이터를 더 잘 처리하는 데 도움이 됩니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. HTTP 상태 코드란 무엇입니까? HTTP 상태 코드는 브라우저가 서버에 요청을 시작할 때 서비스가
