对象的创建方法
- {}
var obj = {}
- 系统自带的构造函数
var obj = new Object()//Array()//Number()
- 自定义的构造函数
function Person(){ } var person1 = new Person()
注:构造函数:大驼峰命名规则 TheFirstName
普通函数:小驼峰命名规则 theFirstName
构造函数内部原理(必须加New)
- 在函数体最前面隐式的加上this={}
- 执行this.xxx=xxx
- 隐式的返回this
function Person(name,age){ //var this={}; 隐式 this.name=name; this.age=age; //return this隐式 } var person1 = new Person("zhangsan",18)
注:构造函数显示返回对象,则返回对象
构造函数返回原始值,则不受影响,继续返回this
包装类
- new String()
- new Boolean()
- new Number()
包装类之后就有属性和方法了,原始值没有属性和方法
var num =4; //new Number(3).len=3; 销毁 num.len=3; //new Number(3).len=3; 销毁 console.log(num.len);
以上过程原始值可以访问属性。经历了隐式的包装类,每次包装完 销毁。
注:undefined和null不可以设置属性值
例1:
// var str = "abcd"; // str.length=2; // new string("abcd").length=2 销毁 // console.log(str)//abcd
例2:
var str = "abc"; str += 1; var test = typeof (str); if (test.length == 6) { test.sign = "typeof的返回结果"; } console.log(test.sign); //undefinde
typeof返回string字符串
---恢复内容结束---
对象的创建方法
- {}
var obj = {}
- 系统自带的构造函数
var obj = new Object()//Array()//Number()
- 自定义的构造函数
function Person(){ } var person1 = new Person()
注:构造函数:大驼峰命名规则 TheFirstName
普通函数:小驼峰命名规则 theFirstName
构造函数内部原理(必须加New)
- 在函数体最前面隐式的加上this={}
- 执行this.xxx=xxx
- 隐式的返回this
function Person(name,age){ //var this={}; 隐式 this.name=name; this.age=age; //return this隐式 } var person1 = new Person("zhangsan",18)
注:构造函数显示返回对象,则返回对象
构造函数返回原始值,则不受影响,继续返回this
包装类
- new String()
- new Boolean()
- new Number()
包装类之后就有属性和方法了,原始值没有属性和方法
var num =4; //new Number(3).len=3; 销毁 num.len=3; //new Number(3).len=3; 销毁 console.log(num.len);
以上过程原始值可以访问属性。经历了隐式的包装类,每次包装完 销毁。
注:undefined和null不可以设置属性值
例1:
// var str = "abcd"; // str.length=2; // new string("abcd").length=2 销毁 // console.log(str)//abcd
例2:
var str = "abc"; str += 1; var test = typeof (str); if (test.length == 6) { test.sign = "typeof的返回结果"; } console.log(test.sign); //undefinde
typeof返回string字符串