对象:函数对象与普通对象
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script>
function fun1(){};
var fun2 = function(){};
var fun3 = new Function();//创建匿名函数对象
var obj1 = new fun1();
var obj2 = {};
var obj3 =new Object();
console.log(Object); // Object() { [native code] }
console.log(Function); // Function() { [native code] }
console.log(fun1); // fun1(){}
console.log(fun2); // (){}
console.log(fun3); // anonymous() {}
console.log(obj1); // fun1 {}
console.log(obj2); // {}
console.log(obj3); // {}
console.log(typeof Object); // function
console.log(typeof Function); // function
console.log(typeof fun1); // function 函数对象
console.log(typeof fun2); // function
console.log(typeof fun3); // function
console.log(typeof obj1); // object 普通对象
console.log(typeof obj2); // object
console.log(typeof obj3); // object
</script>
</head>
<body>
</body>
</html>
data:image/s3,"s3://crabby-images/e93f8/e93f80fb6ce55b84cbd9c83aae92c19044c07df8" alt=""
通过以上知道了 对象分类,接着我们来研究一下原型
prototype 与 proto区别:
data:image/s3,"s3://crabby-images/10631/10631f3355a9a1ea21fdd1e23303a469509f0982" alt=""
1、每一个函数对象都有一个prototype属性,但是普通对象是没有的;prototype下面又有个constructor,指向这个函数。
2、每个对象都有一个名为proto的内部属性,指向它所对应的构造函数的原型对象,原型链基于proto;
我们来看一个例子:
a1,是function所以有prototype
aaa,是object所以有 proto
function a1(){
var a=10;
}
var aaa=new a1();
data:image/s3,"s3://crabby-images/2b9bd/2b9bdf85e9c7b47ee2685cbade99252b7b8dc57b" alt=""
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script>
function a1(){
var a=10;
}
var aaa=new a1();
//以下方法等价 都是执行a1方法
console.log(aaa.constructor);
console.log(a1);
console.log(aaa.__proto__.constructor);
//以下方法等价 都是 a1的原型
console.log(a1.prototype);
console.log(aaa.__proto__);
//原型链
console.log(aaa.__proto__); //a1的原型
console.log(aaa.__proto__.__proto__); //object的原型
console.log(aaa.__proto__.__proto__.__proto__);//null
</script>
</head>
<body>
</body>
</html>
data:image/s3,"s3://crabby-images/c81fe/c81fef54a0270388732665d6b343686f3713e582" alt=""
另外通过以上的例子我们发现了原型链的存在
data:image/s3,"s3://crabby-images/d0fc9/d0fc9fdc23879a03e886d89b75c0d1cbc8b94b9f" alt=""
//原型链
console.log(aaa.__proto__); //a1的原型
console.log(aaa.__proto__.__proto__); //object的原型
console.log(aaa.__proto__.__proto__.__proto__);//null
根据原型我们来探究一下关系
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script>
function a1(num){
this.num=num;
}
var aaa=new a1(10);
var bbb=new a1(20);
console.log(aaa);
console.log(bbb);
a1.prototype={name:"张三",age:20,hobby:['吃饭','睡觉']};
var ccc=new a1(30);
console.log(ccc);
</script>
</head>
<body>
</body>
</html>
data:image/s3,"s3://crabby-images/38655/38655dc76c623b2771d6da56f7dfb7b9fb977666" alt=""
实例里如果没有对应的变量值,则顺着原型链向上(prototype)查找
function a1(num){
this.num=num;
}
var aaa=new a1(10);
var bbb=new a1(20);
console.log(aaa);
console.log(bbb);
a1.prototype={name:"张三",age:20,hobby:['吃饭','睡觉'],num:999};
var ccc=new a1(30);
console.log(ccc);
//查找顺序 如果实例中有打印出实例中的变量值,如果实例中找不到,则向上查找打印出prototype的变量值
console.log(ccc.num);
console.log(a1.prototype.num);
console.log(ccc.__proto__.num);
console.log(ccc.age);
data:image/s3,"s3://crabby-images/2ef4d/2ef4d4fe801166a2b19c13d7c9d8dd50474d9728" alt=""
区分变量数据来源hasOwnProperty() 方法
function aaa () {
}
aaa.prototype.name = "张三";
var a1 = new aaa();
a1.sex = "男";
//sex属性是直接在p1属性中添加,所以是true
console.log("sex属性是对象本身的:" + a1.hasOwnProperty("sex"));
// name属性是在原型中添加的,所以是false
console.log("name属性是对象本身的:" + a1.hasOwnProperty("name"));
// age 属性不存在,所以也是false
console.log("age属性是存在于对象本身:" + a1.hasOwnProperty("age"));
data:image/s3,"s3://crabby-images/648bd/648bd844ac6ad6375d1e13d1f70aac1c9e74b855" alt=""
proto属性指向1.Object对象的prototype 2.function对象的prototype 3.Object.create(a1)的a1对象
1.Object对象的prototype
data:image/s3,"s3://crabby-images/9e056/9e0565ea82028c71d5914c4178000feebd903a0c" alt=""
var a = {};
console.log(a.__proto__ ===Object.prototype);
data:image/s3,"s3://crabby-images/f3ff4/f3ff40b17ebebdf20cb81be0d786106a92f1173b" alt=""
2.function对象的prototype
data:image/s3,"s3://crabby-images/de8ef/de8ef49585ece703be8dedd43f7f769dbd984386" alt=""
var b=function(){};
var a=new b();
console.log(a.__proto__ ===b.prototype);
data:image/s3,"s3://crabby-images/91612/91612b7f73f7e4d5de1944a4f6dde7e081ac5234" alt=""
3.Object.create(a1)的a1对象
data:image/s3,"s3://crabby-images/52150/5215090d35ad3c7cc31b233565c5872f7a74a03c" alt=""
var a1 = {};
var a2 = Object.create(a1);
console.log(a2.__proto__);
console.log(a1);
data:image/s3,"s3://crabby-images/cd682/cd6821da9458910f73e02ba3784801308180677e" alt=""
javascript中的闭包
闭包即内部定义的变量属性,可以突破局部限制,在外部也可以使用。
在java中我们习惯于用内部类来实现闭包。而在javaScript中我们可以通过 来实现闭包。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script>
var dom = function(){
var Name = "tom";
this.Sex = "man";
this.success = function(){
console.log("Success");
};
};
console.log(dom.Name);//undefined
console.log(dom.Sex);//undefined
</script>
</head>
<body>
</body>
</html>
data:image/s3,"s3://crabby-images/90d71/90d714a388b676f9969448fe54bd1e42ac0f5fd9" alt=""
将内部变量作为函数 返回
var person = function(){
//变量作用域为函数内部,外部无法访问
var name = "tom";
return {
getName : function(){
return name;
},
setName : function(newName){
name = newName;
}
}
}();
console.log(person.getName());
person.setName("jerry");
console.log(person.getName());
data:image/s3,"s3://crabby-images/42675/4267533fbe82883842386b6fe9aa9fbbd224eb3d" alt=""
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script>
//javascript 实现闭包的方法 返回对象当中 包含内部元素值
var dom = function(){
var Name = "tom"; //私有属性
this.Sex = "man";
this.success = function(){
console.log("Success");
};
return{
name: Name,
sex:Sex
}
}();
console.log(dom)
console.log(dom.name);
console.log(dom.sex);
// 使用原型对象 来实现 闭包
var dom2 = function(){
var Name = "tom"; //私有属性
this.Sex = "man";
this.success = function(){
console.log("Success");
};
return this;
};
console.log(dom2.prototype.constructor());
console.log(dom2.prototype.constructor().Sex);
//函数降维使用() 数组降维使用[]
var aaa= function(){
alert(123);
}();
console.log(dom.Name);
console.log(dom.Sex);
console.log(dom);
</script>
</head>
<body>
</body>
</html>
javascript继承
function Person(){
var name = "default";
return {
getName : function(){
return name;
},
setName : function(newName){
name = newName;
}
}
};
var Man = function(){};
//继承自Person
Man.prototype = new Person();
//添加私有方法
Man.prototype.say = function(){
console.log("Hello,my sex is man");
};
var aaa = new Man();
aaa.setName("tom");
aaa.say();
console.log(aaa.getName());
data:image/s3,"s3://crabby-images/826f1/826f1104c6cc1b0ff0fa6d16502de4fea93ecb08" alt=""
网友评论