js的类与继承
来源:互联网 发布:人工智能工程师的一天 编辑:程序博客网 时间:2024/05/21 17:00
鉴于长时间不写前端代码以至于很多复杂的js代码拿过来读都有点吃力,就把一些知识点总接起来。
首先巩固下知识:
js把对象分为俩种其一是普通对象(Object自带对象)其二是函数对象(Function自带对象), new Function()出来的是函数对象其他则为普通对象;当然很多时候你看到的当然不是很直白的这种形式,就像函数对象创建就有多种形式。
在JavaScript 中,每当定义一个对象(函数)时候,对象中都会包含一些预定义的属性。其中函数对象的一个属性就是原型对象 prototype。注:普通对象没有prototype,但有proto属性。
看下例子
function f1(){};
console.log(f1.prototype) //f1{}
console.log(typeof f1. prototype) //Object
console.log(typeof Function.prototype) // Function,这个特殊
console.log(typeof Object.prototype) // Object
console.log(typeof Function.prototype.prototype) //undefined
1.js的类对象申明的创建:
1)原型:
function Cat() { this.name = "大毛"; }var cat1 = new Cat();alert(cat1.name); // 大毛Cat.prototype.makeSound = function(){ alert("喵喵喵");}
2)、Object.create()法
var Cat = { name: "大毛", makeSound: function(){ alert("喵喵喵"); } }; var cat1 = Object.create(Cat); alert(cat1.name); // 大毛 cat1.makeSound(); // 喵喵喵
3)、极简主义法
这种方法不使用this和prototype,代码部署起来非常简单,这大概也是它被叫做”极简主义法”的原因。
首先,它也是用一个对象模拟”类”。在这个类里面,定义一个构造函数createNew(),用来生成实例。
var Cat = { createNew: function(){ // some code here } };
然后,在createNew()里面,定义一个实例对象,把这个实例对象作为返回值。
var Cat = { createNew: function(){ var cat = {}; cat.name = "大毛"; cat.makeSound = function(){ alert("喵喵喵"); }; return cat; } };
使用的时候,调用createNew()方法,就可以得到实例对象。
var cat1 = Cat.createNew(); cat1.makeSound(); // 喵喵喵
让一个类继承另一个类,实现起来很方便。只要在前者的createNew()方法中,调用后者的createNew()方法即可。
先定义一个Animal类
var Animal = { createNew: function(){ var animal = {}; animal.sleep = function(){ alert("睡懒觉"); }; return animal; } };
然后,在Cat的createNew()方法中,调用Animal的createNew()方法。
var Cat = { createNew: function(){ var cat = Animal.createNew(); cat.name = "大毛"; cat.makeSound = function(){ alert("喵喵喵"); }; return cat; } };
这样得到的Cat实例,就会同时继承Cat类和Animal类。
var cat1 = Cat.createNew(); cat1.sleep(); // 睡懒觉
私有属性和私有方法
在createNew()方法中,只要不是定义在cat对象上的方法和属性,都是私有的
var Cat = { createNew: function(){ var cat = {}; var sound = "喵喵喵"; cat.makeSound = function(){ alert(sound); }; return cat; } };
上例的内部变量sound,外部无法读取,只有通过cat的公有方法makeSound()来读取。
var cat1 = Cat.createNew(); alert(cat1.sound); // undefined
数据共享
有时候,我们需要所有实例对象,能够读写同一项内部数据。这个时候,只要把这个内部数据,封装在类对象的里面、createNew()方法的外面即可。
var Cat = { sound : "喵喵喵", createNew: function(){ var cat = {}; cat.makeSound = function(){ alert(Cat.sound); }; cat.changeSound = function(x){ Cat.sound = x; }; return cat; } }; var cat1 = Cat.createNew(); var cat2 = Cat.createNew(); cat1.makeSound(); // 喵喵喵 //这时,如果有一个实例对象,修改了共享的数据,另一个实例对象也会受到影响。 cat2.changeSound("啦啦啦"); cat1.makeSound(); // 啦啦啦
原文:http://www.ruanyifeng.com/blog/2012/07/three_ways_to_define_a_javascript_class.html
- js的类与继承
- JS类与继承
- JS的类式继承与原型式继承
- js类的继承
- js类的继承
- JS中类的创建与继承的理解
- JS-12-类的继承与构造器
- js中es5类的创建继承与es6中类的创建继承
- 深入浅出JS的封装与继承
- JS继承-类继承
- JS模拟类的继承
- JS 继承与扩展
- JS 继承与重写
- 类的一般继承与虚继承
- js函数(类)的继承机制的设计与实现
- js函数(类)的继承机制的设计与实现(二)
- js函数(类)的继承机制的设计与实现(三)
- js函数(类)的继承机制的设计与实现(四)
- MYSQLsh: ./bin/my_print_defaults: /lib/ld-linux.so.2: bad ELF interpreter: No such file or directory
- [iOS 按钮选择] 记录按钮点击 selected 的代码
- 【JAVA语言程序设计基础篇】--事件驱动程序设计--Timer类的动画
- iOS freeImage静态库编译(makefile)
- 浅谈控制器跳转问题
- js的类与继承
- Redis与Memcached的区别
- perl程序提示Can't locate sys/ioctl.ph in @INC
- 菜鸟的成神之路
- 面试5-线程
- 记载我学习go的过程(四)
- Java调用win32API与DLL的使用
- 从红楼梦看NoSQL数据库
- Windows下硬链接、软链接和快捷方式的区别