>웹 프론트엔드 >JS 튜토리얼 >하나의 기사로 JavaScript 객체 마스터하기

하나의 기사로 JavaScript 객체 마스터하기

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB앞으로
2022-05-09 17:57:122053검색

이 글은 javascript에 대한 관련 지식을 제공합니다. 객체지향, 객체 연산, 속성 명명 등 객체와 관련된 문제를 주로 소개합니다. 모두에게 도움이 되기를 바랍니다. 도움이 되는.

하나의 기사로 JavaScript 객체 마스터하기

【관련 권장 사항: javascript 비디오 튜토리얼, web front-end

JavaScript object

JavaScript의 8가지 데이터 유형(7가지 기본 데이터 유형 포함) 숫자, BigInt, 문자열, 부울, null, 정의되지 않음 및 <code>symbol) 및 복합 유형 object(즉, 객체 유형)입니다. JavaScript的八种数据类型,其中包括七种原始的数据类型(NumberBigIntStringBooleannullundefinedsymbol)和一种复杂类型object(也就是对象类型)。

相比于原始数据类型,object之所以被称为复杂类型,是因为原始类型仅仅能表示一种数据,例如Number表示数字,String表示字符串等,而object可以通过键值对的形式,包含所有的原始数据类型。

例如,我们可以使用symbol类型表示对象的ID,用String类型表示对象的名字,用Boolean表示对象的性别等等。对象中的每一个类型的数据都被称为对象的一个属性,一个对象理论上可以有无数个属性,这些属性统一在一对花括号{...}中创建。

面向对象不仅仅是JavaScript的语言特性,实际上在所有的面向对象语言,如C++JavaPythonC#中都是非常重要的概念。想要学好JavaScript,必须熟练乃至精通对象的特性,因为对象渗透了JavaScript的方方面面。

面向对象 VS 面向过程

面向对象是一种编程思想,并非新的技术。在面向对象出世之前,程序员都是以面向过程的思想组织大量代码的。

何为面向对象?这个问题在学校和面试中会被经常问到。我们可以极其高深的理解回答:万物皆对象,虽然这绝对正确,却并不是面试管或者老师想要的答案。

面向对象是一种编程思想,一种组织代码的方式,是相对于面向过程而言的。在面向过程中,程序员就是上帝,上帝指挥指挥着所有的一切。例如我们常举的一个例子:把大象装进冰箱。
在面向过程中,把上帝需要先把冰箱门打开,然后把大象放进冰箱,最后把冰箱门关上。所有过程由上帝一个人操作。
在面向对象中,冰箱和大象都是存在的一个对象,而且冰箱会自己开门,大象也会自己进冰箱,然后冰箱自己把门关上即可。整个过程由上帝协调,但是具体做事的过程由对象自己完成,比如如何打开冰箱门,如何走进冰箱等。

语法

定义一个对象不需要使用关键字,直接使用花括号{..}包裹键值对就能创建对象,语法如下:

let child = {
	name:'Tom',
	age:8,}

以上代码就创建了一个简单的对象,并把对象赋值给了变量childchild对象拥有两个属性(两个值),一个是name,另一个是age
所谓键值对(key:value),就是简单的名称和值之间的映射。
例如上例中的name:'Tom'就是一个键值对,其中name是键,"Tom"是对应的值。实际使用过程中,可以通过键获得对应的值,就像使用变量名称获得变量值是一样的。

空对象

如果一个对象中没有任何属性,那么这个对象就是一个空对象。我们可以通过简单的把{}赋值给一个变量获得空对象,还可以使用另外一种方式:

let nullObj1 = {};		
//创建也给空的对象let nullObj2 = new Object();	
//同样创建了一个空对象

对象操作

一个对象创建之后,并非一成不变的,我们在使用对象的过程中,随时都可以查询对象的属性,或者更改对象。

查询属性

查询对象的属性值,需要使用一个新的符号:.,语法是对象名.变量名

举个简单的小李子:

let child = {
	name:'Tom',
	age:8,};console.log(child.name);console.log(child.age)

代码执行结果如下:

하나의 기사로 JavaScript 객체 마스터하기

在上述案例中,如果我们想查看变量child中的name属性,只需要简单的使用child.name

기본 데이터 유형과 비교하여 객체는 한 종류의 데이터만 나타낼 수 있으므로 객체는 복합 유형이라고 합니다. 예를 들어 Number는 숫자를 나타내고 는 >String은 문자열 등을 나타내는 반면, object는 🎜키-값 쌍🎜 형태의 모든 기본 데이터 유형을 포함할 수 있습니다. 🎜🎜예를 들어 symbol 유형을 사용하여 개체의 ID를 나타내고 String 유형을 사용하여 개체 이름을 나타낼 수 있으며 Boolean code>는 객체의 성별 등을 나타냅니다. 객체에 있는 각 데이터 유형을 객체의 🎜속성🎜이라고 합니다. 객체는 이론적으로 한 쌍의 중괄호 {...}로 통합되는 수많은 속성을 가질 수 있습니다. 🎜🎜🎜객체 지향🎜은 JavaScript의 언어 기능뿐만 아니라 C++, Java와 같은 모든 객체 지향 언어에도 적용됩니다. >, Python과 C#은 모두 매우 중요한 개념입니다. JavaScript를 잘 배우고 싶다면 객체의 특성에 능숙하거나 심지어 능숙해야 합니다. 왜냐하면 객체는 JavaScript의 모든 측면을 관통하기 때문입니다. 🎜🎜객체 지향 VS 프로세스 지향🎜🎜객체 지향은 프로그래밍 아이디어이지 새로운 기술이 아닙니다. 객체지향이 탄생하기 전 프로그래머들은 프로세스지향적 사고를 바탕으로 엄청난 양의 코드를 정리했습니다. 🎜🎜객체지향이란 무엇인가요? 이 질문은 학교나 면접에서 자주 묻는 질문입니다. 우리는 그 대답을 매우 심오하게 이해할 수 있습니다: 🎜모든 것이 대상입니다🎜 이것은 절대적으로 정확하지만 면접관이나 교사가 원하는 대답은 아닙니다. 🎜🎜객체 지향은 🎜프로세스 지향🎜과 관련된 프로그래밍 아이디어이자 코드 구성 방법입니다. 프로세스 지향에서는 프로그래머가 신이고, 신이 모든 것을 지휘하고 지휘합니다. 예를 들어, 우리는 종종 코끼리를 냉장고에 넣는 예를 들었습니다.
하나님을 대면하는 과정에서는 먼저 냉장고 문을 열고, 그다음 코끼리를 냉장고에 넣고, 마지막으로 냉장고 문을 닫아야 합니다. 모든 과정은 하나님께서만 운영하십니다.
객체지향에서는 냉장고와 코끼리가 모두 기존 객체이고, 냉장고가 스스로 문을 열고, 코끼리가 스스로 냉장고에 들어가고, 냉장고가 스스로 문을 닫습니다. 모든 과정은 하나님께서 주관하시지만, 냉장고 문을 여는 방법, 냉장고에 들어가는 방법 등 구체적인 일을 하는 과정은 주체가 직접 완성한다. 🎜🎜Syntax🎜🎜객체를 정의하기 위해 키워드를 사용할 필요는 없습니다. 키-값 쌍을 중괄호 {..}로 묶어 객체를 생성할 수 있습니다. : 🎜
let child = {
	name:'Tom',
	age:8,}child.height = 800;//创建了一个新的属性heightconsole.log(child.height);
🎜위 코드는 간단한 객체를 생성하고 해당 객체를 변수 child에 할당합니다. child 개체에는 두 개의 속성(두 개의 값)이 있습니다. 하나는 name이고 다른 하나는 age입니다.
소위 키-값 쌍(key:value)은 이름과 값 사이의 간단한 매핑입니다.
예를 들어, 위 예에서 name:'Tom'은 키-값 쌍입니다. 여기서 name은 키이고 "Tom"는 해당 값입니다. 실제 사용에서는 변수명을 이용하여 변수값을 구하는 것과 마찬가지로 키를 통해 해당 값을 구할 수 있다. 🎜🎜빈 객체🎜🎜객체에 속성이 없으면 객체는 빈 객체입니다. 간단히 {}를 변수에 할당하여 빈 객체를 얻을 수 있습니다. 또한 다른 방법을 사용할 수도 있습니다. 🎜
let child={
	name:'Tom',
	age:8,}child.age=12;console.log(child);
🎜객체 작업🎜🎜객체가 생성된 후에는 정적이 아닙니다. 개체를 생성하는 과정에서 언제든지 개체의 속성을 쿼리하거나 개체를 변경할 수 있습니다. 🎜

속성 쿼리

🎜객체의 속성 값을 쿼리하려면 새 기호 .를 사용해야 하며 구문은 객체 이름.변수 이름입니다. 코드>. 🎜🎜간단한 예를 들자면: 🎜
let child = {
	name:'Tom',
	age:8,}delete child.age;console.log(child);
🎜코드 실행 결과는 다음과 같습니다. 🎜🎜속성 쿼리🎜🎜위의 경우 child 변수의 name 속성을 ​​보려면 간단히 다음을 사용하면 됩니다. child.name이 됩니다. 🎜

增加属性

在一个对象变量创建完成后,我们还可以随时向变量中添加新的属性,方法如下:

let child = {
	name:'Tom',
	age:8,}child.height = 800;//创建了一个新的属性heightconsole.log(child.height);

代码执行结果如下:

向对象变量中添加新的属性,只需要直接使用.属性名,然后直接向新属性赋值即可。

如果我们此时查看变量child的内容,可以发现height属性已经位列其中了:

对象的属性类型可以是任意的,我们可以直接使用child.isBoy=true向对象中添加布尔值,或者使用child.money=null添加一个值为空的属性。

更改属性

JavaScript对象更改属性值也非常简单,直接向变量赋值就可以了,举个简单的小李子:

let child={
	name:'Tom',
	age:8,}child.age=12;console.log(child);

代码执行结果如下:

可以看到,age变量已经从8变成了12

删除属性

对象删除属性需要使用一个新的关键字delete,使用delet 对象名.属性名删除对象的属性:

let child = {
	name:'Tom',
	age:8,}delete child.age;console.log(child);

代码执行结果如下:

从代码的执行结果可以看到属性age已经被删掉了。

多单词键值

对象的属性名(键)还能够使用空格隔开的多个单词,不过在创建此类属性时需要使用双引号把键名包裹起来。

举个例子:

let child={
	name = 'Tom',
	age:8,
	"favorite cat":'Jerry',}

以上代码就创建了一个键名为"favorite cat"的键值对,但是在访问属性值的时候,如果使用:

child.favorite cat = 'Bob'; //语法错误

这种方式是错误的,引擎会把favorite当作一个键名,并在遇到cat时报错。

访问此类键值,就需要方括号

方括号

.可以访问普通的属性名,在例如"favorite cat"之类的变量时可以使用[],举个例子:

let child={
	name:'Tom',
	age:8,
	"favorite cat":'Jerry',}console.log(child['favorite cat']);

代码执行结果如下:

方括号提供了.之外的属性访问方式,我们完全可以通过方括号代替.来操作对象的属性。

例如:

let child = {
	name:'Tom',
	age:8,}child['favorite cat']='Jerry';	
	//增加属性child['name']='Bob';			
	//修改属性delete child['age'];			
	//删除数console.log(child['name']);		
	//查看属性

除了常规的属性操作之外,方括号还能通过变量访问对象属性:

let child = {
	name:'Tom',
	age:8,}let prop = 'name';console.log(child[prop]);prop='age';console.log(child[prop]);

通过变量访问属性值的能力为我们提供了非常有用的变量访问方式,例如我们可以在程序中计算出属性的键名,然后再通过键名访问键值。

举个栗子:

let child = {
	prop1:0,
	prop2:1,
	prop3:2,}let prop = 'prop';for(let i=1;i<p>在这里,范围属性值的<code>key</code>是通过计算得到的,这一功能用<code>.</code>是不能实现的。</p><h2>计算属性</h2><p>在创建对象时,我们还可以通过变量指定对象的键名,此类属性叫做<strong>计算属性</strong>。</p><p>举个例子:</p><pre class="brush:php;toolbar:false">let propName = 'name';let child ={
	[propName]:'Tom',
	age:8,}

代码执行结果如下:

> let propName = 'name';
> let child ={
 	[propName]:'Tom',
 	age:8,
> }
> undefined
> child
> {name: 'Tom', age: 8}

上例中的[propName]就是一个计算属性,意义也非常简单,就是使用变量propName中存储的值(此处为"name")作为对象的键名。

以上的代码本质上和下面的代码作用相同:

let propName='name';let child = {
	age:8,}child[propName]='Tom';

方括号中还可以使用复杂的表达式:

let child = {['prop' + 2 * 3]:'Tom',}

代码执行结果如下:

> let child = {
	['prop'+2*3]:'Tom',
  } child<h2>属性简写</h2><p>在实际应用中,或者匿名对象中,我们常常会使用和变量同名的属性,举个例子:</p><pre class="brush:php;toolbar:false">let name = 'Tom';let age = 8;let child = {
	name:name,	//属性名和变量名一样,都是name
	age:age,};

这种情况下,我们就可以简写对象属性,如下:

let name = 'Tom';let age = 8;let child = {
	name, // 等同于name:name;
	age,}

代码的执行结果:

> let name = 'Tom';
  let age = 8;
  let child = {
		name,
		age,
  } child<h2>属性命名</h2><p>和变量命名不同,我们几乎可以使用任何值作为属性的名称,包括关键字和数字:</p><h3>关键字作为变量名</h3><p>虽然听起来不可思议,实际上,所有的关键字都可以作为对象的属性名:</p><pre class="brush:php;toolbar:false">let obj = {
	for:0,
	while:1,
	function:2,
	alert:3,}

代码执行结果:

> let obj = {
  	for:0,
  	while:1,
  	function:2,
  	alert:3,
  } obj<h3>数字作为关键字</h3><p>数字也可以作为关键字的名称,如下:</p><pre class="brush:php;toolbar:false">let obj = {
	0:'Number',//隐式转换为"0"
	1:'Number',}console.log(obj['0']);

数字作为属性名称时,会被隐式转换为字符串,在访问属性时,不能使用.,必须使用方括号代替。

属性名称中的陷阱

在命名中,有一个小陷阱,我们不能使用__proto__作为属性的名称,这个属性是对象的一个特殊,后继会特别介绍。

举个例子:

let obj = {};obj.__proto__ = 1;console.log(obj.__proto__);

in 操作符

JavaScript有一个需要注意的特性,即使访问一个不存的属性时也不会报错,仅仅是返回undefined
那我们如何知道,属性是否存在于对象之中呢?

最简单的方式是使用if语句:

let obj = {};if(obj.someProp === undefined){
	...}

这么做在大部分情况下是没有问题的,但是当属性名称的值就是undefined本身时,就会出现错误:

let obj = {
	prop : undefined}obj.prop === undefined ? console.log('no'):console.log('yes');

代码执行结果:

> let obj = {
  	prop : undefined
  }
  obj.prop === undefined ? console.log('no'):console.log('yes');
  no<p>虽然<code>prop</code>是存在的,但是以上案例并不能正确的返回结果。</p><p>这个时候就需要使用<code>in</code></p><pre class="brush:php;toolbar:false">let obj = {
	prop:undefined,};if('prop' in obj){
	console.log('yes');}else{
	console.log('no');}

这么做是不是优雅了许多呢?

> let obj = {
  	prop:undefined,
  };
  if('prop' in obj){
  	console.log('yes');
  }else{
  	console.log('no');
  }<h2>属性遍历</h2><p>如果我们不知道对象中都存在什么属性,如何取得所有的属性值呢?<br> 这时候就需要使用<code>for .. in ..</code>语句了,它类似于<code>for</code>循环,但是更简洁。</p><p><strong>语法</strong></p><pre class="brush:php;toolbar:false">for (key in obj){
	...}

举个简单的小李子:

let child = {
	name:'Tom',
	age:8,
	height:180,}for (let key in child){
	console.log(key+':'+child[key]);}

代码执行结果如下:

> let child = {
  	name:'Tom',
  	age:8,
  	height:180,
  }

  for (let key in child){
  	console.log(key+':'+child[key]);
  }<h2>属性顺序</h2><p>当我们创建一个对象并遍历其中所有的属性时,属性是如何排列的呢?答案是:特别的顺序排列,并遵循以下规则:</p><ol>
<li>数字属性以数字顺序排列;</li>
<li>其他属性按照创建顺序排列;</li>
<li>数字属性在其他属性之前;</li>
</ol><p>举个例子:</p><pre class="brush:php;toolbar:false">let obj = {
	name:'Tom',
	age:99,
	7:'7',
	1:'1',
	9:'9',}for (let key in obj){
	console.log(key+':'+obj[key]);}

代码执行结果:

> let obj = {
  	name:'Tom',
  	age:99,
  	7:'7',
  	1:'1',
  	9:'9',
  }
  for (let key in obj){
  	console.log(key+':'+obj[key]);
  }<p>【相关推荐:<a href="https://www.php.cn/course/list/17.html" target="_blank" textvalue="javascript视频教程">javascript视频教程</a>、<a href="https://www.php.cn/course/list/1.html" target="_blank">web前端</a>】</p>

위 내용은 하나의 기사로 JavaScript 객체 마스터하기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제