对象和包装类

本文深入探讨JavaScript中对象的创建方法,包括对象字面量、构造函数等,并解析构造函数的工作原理及其如何帮助实现对象的增删改查操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上面代码也可以这样写

对于一个对象来说,肯定要有增删改查

首先来看增:

再看查看:

在看改:

再看删

对象的创建方法:

1,var obj = {}   ,plainObject  对象字面量,对象直接量

2,构造函数

(1)系统自带的构造函数  Object()

js的构造函数可以后天更改对象属性

(2)自定义

符合大驼峰式命名规则// TheFirstName

可以从共同的函数中继承共同的属性,并且各不影响

 

构造函数的原理:

var student = new Student('zhangsan', 18, 'male');

1,在函数体最前面隐式的加上this = {}

在你使用过new之后,原本函数内部的最前会加上var this = {};

2,执行this.xxx = xxx;

3,隐式的返回this

看下面:

如果我们现在自己返回对象

就会返回空对象

现在我们返回一个原始值:

发现没什么作用,这是因为在你new了之后,就只能返回对象了,返回原始值的语句没有什么效果

如果我们自定义this对象

-------------------------------------------------------------------------------------------------------------------------

我们再来看包装类

变成了对象 123

那么他还能不能有和数字的运算呢?,答案是可以的

但是要记得哦,乘过数字之后,原本的对象就变成了数字

对于字符串和布尔也是一样的

undefined和null不能设置属性

总结一下:比如数字(string和booleant同理),数字有原始值数字和对象数字,原始值数字不能有对象和方法,对象能有对象和自己的方法

那么看下面的:

再看下面的:

发现没有报错,原因是经过了一个包装类的过程

在这个过程中,首先声明了一个原始值,然后我们为其添加了一个方法,这本来是不正确的,但是系统为我们隐式调用了Number()方法,将他变成了一个对象,并添加了len属性赋值为3,随即系统就调用delete方法,将对象删除(可以这样理解,你使用了一个错误的方法,但是系统不忍心提醒你,为你将num变成了对象而且添加了len属性,但是系统知道原始值不能有属性,于是就将len删除了),但是我们又自己调用了len属性,这个时候系统说,兄弟你这不行啊,不涨记性,但是系统任然不想提醒你,于是又new了number对象(但是这个和刚才那个number对象不是一个),再去访问len,在一个对象里访问未经声明的变量,系统会返回undefined

那么现在看下面的问题:

我们发现length有截断字符串的作用,再看

看看会是多少?ab?不是,abcd

记住.length是对象str的属性,如果我们访问str.length,系统会为我们new 一个String对象,里面存的是abcd,然后调用.length方法再返回str的长度

在看下面的:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值