对象

为什么要有对象?

如果函数参数很多的时候,可以使用对象进行简化。

  • 事物的特征在对象中用属性来表示。
  • 事物的行为在对象中用方法来表示。

对象创建方式

一、对象字面量

							 var o = {
							  name: 'zs,
							  age: 18,
							  sex: true,
							  sayHi: function () {
							    console.log(this.name);
							  }
							};

二、 new Object() 创建对象

							var person = new Object();
							person.name = 'lisi';
							person.age = 35;
							person.job = 'actor';
							person.sayHi = function() {
							  console.log('Hello,everyBody');
							}

三、工厂函数创建对象

							function createPerson(name, age, job) {
							  var person = new Object();
							  person.name = name;
							  person.age = age;
							  person.job = job;
							  person.sayHi = function(){
							    console.log('Hello,everyBody');
							  }
							  return person;
							}
							var p1 = createPerson('张三', 22, 'actor');

四、自定义构造函数

							function Person(name, age, job){
							  this.name = name;
							  this.age = age;
							  this.job = job;
							  this.sayHi = function(){
							  	console.log('Hello,everyBody');
							  }
							}
							var p1 = new Person('张三', 22, 'actor');

a. 属性和方法

  • 如果一个变量属于一个对象所有,那么该变量就可以称之为该对象的一个属性,属性一般是名词,用来描述事物的特征
  • 如果一个函数属于一个对象所有,那么该函数就可以称之为该对象的一个方法,方法是动词,描述事物的行为和功能

b. new 关键字

构造函数 ,是一种特殊的函数。主要用来在创建对象时初始化对象, 即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中。

  1. 构造函数用于创建一类对象,首字母要大写。
  2. 构造函数要和new一起使用才有意义。

new在执行时会做四件事情

  1. new会在内存中创建一个新的空对象
  2. new 会让this指向这个新的对象
  3. 执行构造函数 目的:给这个新对象加属性和方法
  4. new会返回这个新对象

c. this 详解

JavaScript中的this指向问题,有时候会让人难以捉摸,随着学习的深入,我们可以逐渐了解
现在我们需要掌握函数内部的this几个特点

  1. 函数在定义的时候this是不确定的,只有在调用的时候才可以确定
  2. 一般函数直接执行,内部this指向全局window
  3. 函数作为一个对象的方法,被该对象所调用,那么this指向的是该对象
  4. 构造函数中的this其实是一个隐式对象,类似一个初始化的模型,所有方法和属性都挂载到了这个隐式对象身上,后续通过new关键字来调用,从而实现实例化
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值