

上面代码也可以这样写

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


再看查看:


在看改:


再看删


对象的创建方法:
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的长度
在看下面的:


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

被折叠的 条评论
为什么被折叠?



