zoukankan      html  css  js  c++  java
  • js 原型规则与示例

    五大规则

    1. 所有的引用类型( 数组 对象 函数 ) 都是 具有对象特性即自由拓展属性 (除了 ”null“)意外

    2. 所有的引用类型(数组 对象 函数 ) 都有一个 proto 属性属性值是一个普通的对象

    3. 所有的函数 都有一个prototype 属性 ,属性值也是一个普通的对象

    4. 所有的引用类型(数组 对象 函数),proto 属性值指向它的构造函数 ”prototype“ 属性值

    5. 当试图得到一个对象的某个属性时,如果这个对象本身没有这个属性那么会去它的__proto__(即它的构造函数的prototype寻找)

    示例

    <script>
    
    	// 构造函数
    
    	function Foo(name , age){
    
    		this.name = name;
    		this.age = age;
    		this.class = "class-1";
    
    		return this; // 默认有这一行
    	}
    
    	var f = new Foo( "bobo" ,22); // 实例化对象
    
    	var a = {} 其实 是 var a = new Object();
    
    	var a = [] 其实 是 var  a = new Array();
    
    	function Foo(){} 其实 是 var  Foo = new Function();
    
    	 使用instanceof 判断函数是否是一个变量的构造函数
    
    	 如何判断一个变量是不是数组 : 用instanceof Array
    
     // 二、原型规则和示例
    
     // 原型规则是学习原型链的基础
    

    1. 所有的引用类型( 数组 对象 函数 ) 都是 具有对象特性 即自由拓展属性 (除了 ”null“)意外

    	 拓展性
    	 var obj = {} ; a.age = 100;
    	 var arr = [] ; b.a = 100;
    	 function fn (){}
    	 fn.a = 100;
    
    

    2. 所有的引用类型(数组 对象 函数 ) 都有一个 proto 属性,属性值是一个普通的对象

    	 // __proto__ 隐式类型
    
    	 console.log(obj.__proto__);
    	 console.log(arr.__proto__);
    	 console.log(fn.__proto__);
    

    3. 所有的函数 都有一个prototype 属性 ,属性值也是一个普通的对象

    	 // prototype 显示类型
    
    	 console.log( fn.prototype );
    
    

    4. 所有的引用类型(数组 对象 函数),proto 属性值指向 它的构造函数 ”prototype“ 属性值

    	 console.log( obj.__proto__ === Object.prototype)
    

    5. 当试图得到一个对象的某个属性时,如果这个对象本身没有这个属性 那么会去它的__proto__(即它的构造函数的prototype寻找)

    	 // 构造函数
    
    	 function Foo(name , age ){
    
    	 	this.name = name ;
    	 }
    
    	 Foo.prototype.alertName = function(){
    
    	 	alert( this.name );
    	 }
    
    	 // 创建示例
    
    	 var f = new Foo("zhangsan");
    
    	 f.printName = function(){
    
    	 	console.log(this.name);
    	 }
    
    	 // 测试
    
    	 f.printName();
    	 f.alertName(); 
    

    6. this

    7. 循环对象自身的属性

    	 var item ;
    
    	 for( item in f ){
    
    	 	高级浏览器已经在 for in 中屏蔽了来自原型(prototype)的属性
    
    	 	但是这里建议大家还是加上这个判断
    
    	 	保证程序的健壮性
    
    	 	if( f.hasOwnProperty(item)){
    
    	 		console.log(item)
    
    	 	}
    	 }
    
    </script>
    
    
  • 相关阅读:
    关于Thread ThreadPool Parallel 的一些小测试demo
    VS附加到进程调试
    netcore 实现一个简单的Grpc 服务端和客户端
    CodeSmith 找不到请求的 .Net Framework Data Provider
    ocelot集成consul服务发现
    使用ocelot作为api网关
    关于add migration 报错的问题解决方案
    关于多线程efcore dbcontext 的解决方案。
    docker mysql 容器报too many connections 引发的liunx磁盘扩容操作
    关于liunx 机器脱机环境(netcore)Nuget包迁移的问题
  • 原文地址:https://www.cnblogs.com/liangfengbo/p/7430205.html
Copyright © 2011-2022 走看看