js中的对象基础

什么是对象

现实生活中:万物皆对象,对象是一个具体的事物,一个具体的事物就会有行为和特征。

车是一类事物,门口停的那辆车才是对象。特征:红色、四个轮子,行为:驾驶、刹车

JavaScript的对象是无序属性的集合。

其属性可以包含基本值、对象或函数。对象就是一组没有顺序的值。

我们可以把JavaScript中的对象想象成键值对,其中值可以是数据和函数。

创建对象

对象字面量
    // 创建一个电脑对象,有颜色,有重量,有品牌,有型号,可以看电影,可以听音乐,可以打游戏,可以敲代码
var obj1={
    color : "red",
    weight : 100,
    brand : 'sx',
    Model : 10012,
    color: 'ggg',
    Movie : function(){
        return "请看->电影";
    },
    Game : function(){
        return "给了游戏一巴掌";
    },
    Code : function(){
        return "我敲,代码"
    }
}
//下列是用new创建对象
var obj3 = new Object()
obj3.color= 'red';
obj3.weight = 100;
obj3.brand = 'sx';
obj3.Model = 10012;
obj3.Movie = function(){
        return "请看->电影";
    };
obj3.Game = function(){
        return "给了游戏一巴掌";
    };
obj3.Code = function(){
        console.log("我敲,代码");//在方法中写打印语句调用时直接用 对象.方法因为没有返回值
    };
工厂函数创建对象
// 创建一个按钮对象,宽,高,背景颜色,点击行为
function bbutton(width,height,bgcolor){
    var anniu = new Object();
    anniu.width = width;
    anniu.height = height;
    anniu.bgcolor = bgcolor;
    anniu.active = function(){
        console.log('点击');
    }
    return anniu
}
var b1=bbutton(10,10,"#e0e0e0")
可var多个简便的创建
自定义构造函数
// 创建一个车的对象,有重量,颜色,牌子,可以载人,拉货
function Car(weight,color,brand){
    this.weight=weight;
    this.color=color;
    this.brand=brand;
    this.person=function(i){
        console.log("拉走了"+i+"个人");
    }
    this.ll=function(n){
        console.log('拉走了'+n)
    }
}
var c1= new Car(100,"fff",'Toyota')
也可以var多个

调用:

用对象名.属性(可以是属性或函数)

对象名[“属性”](只能输出值,不能在里面放函数名)

属性和方法

1. 如果一个变量属于一个对象所有,那么该变量就可以称之为该对象的一个属性,属性一般是名词,用来描述事物的特征

2. 如果一个函数属于一个对象所有,那么该函数就可以称之为该对象的一个方法

new关键字

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

1.、构造函数用于创建一类对象,首字母要大写。

2.、构造函数要和new一起使用才有意义。

new在执行时会做三件事情:

1、new会在内存中创建一个新的空对象

2、new会让this指向这个新的对象

3、new会返回这个新对象

this详解

函数内部的this几个特点:

1. 函数在定义的时候this是不确定的,只有在调用的时候才可以确定

2. 一般函数直接执行,内部this指向全局window

3. 函数作为一个对象的方法,被该对象所调用,那么this指向的是该对象

4. 构造函数中的this其实是一个隐式对象,类似一个初始化的模型,所有方法和属性都挂载到了这个隐式对象身上,后续通过new关键字来调用,从而实现实例化

比如有一个函数function()调用function(arr)在这个函数内的this都指向这个arr

遍历对象的属性,不是遍历值

通过for..in语法可以遍历一个对象

for (key in 对象名){}

// 创建一个车的对象,有重量,颜色,牌子,可以载人,拉货
function Car(weight,color,brand){
    this.weight=weight;
    this.color=color;
    this.brand=brand;
    this.person=function(i){
        console.log("拉走了"+i+"个人");
    }
    this.ll=function(n){
        console.log('拉走了'+n)
    }
}
var c1= new Car(100,"fff",'Toyota')
console.log(c1);
for(key in c1){
    console.log(key);
}
c1.person(5)//调用方法
c1.ll('邻居')
for输出这个:weight,color,brand,person,ll

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值