首页 > web前端 > js教程 > 正文

极简主义法完成JavaScript的封装和继承

小云云
发布: 2017-11-30 09:25:36
原创
1531人浏览过

本文我们要讲一个对于初学人员来说比较新颖的知识:极简主义法编写JavaScript类。"极简主义法"是荷兰程序员Gabor de Mooij提出来的,这种方法不使用this和prototype,代码部署起来非常简单,这大概也是它被叫做"极简主义法"的原因。下面就介绍如何使用极简主义法完成JavaScript的封装和继承,希望对大家有帮助。

1. 封装

  首先,它也是用一个对象模拟"类"。在这个类里面,定义一个构造函数createNew(),用来生成实例。

var Cat = {
    createNew: function(){
      // some code here
    }
};
登录后复制

   

立即学习Java免费学习笔记(深入)”;

  然后,在createNew()里面,定义一个实例对象,把这个实例对象作为返回值。

var Cat = {
     createNew: function(){
       var cat = {};
       cat.name = "大毛";
       cat.makeSound = function(){ alert("喵喵喵"); };
       return cat;
     }
 };
登录后复制

   

立即学习Java免费学习笔记(深入)”;

使用的时候,调用createNew()方法,就可以得到实例对象。

var cat1 = Cat.createNew();
cat1.makeSound(); // 喵喵喵
登录后复制

  这种方法的好处是,容易理解,结构清晰优雅,符合传统的"面向对象编程"的构造,因此可以方便地部署下面的特性。

2. 继承

  让一个类继承另一个类,实现起来很方便。只要在前者的createNew()方法中,调用后者的createNew()方法即可。
  先定义一个Animal类:

var Animal = {
    createNew: function(){
      var animal = {};
      animal.sleep = function(){ alert("睡懒觉"); };
      return animal;
    }
};
登录后复制

   

立即学习Java免费学习笔记(深入)”;

  然后,在Cat的createNew()方法中,调用Animal的createNew()方法

var Cat = {
     createNew: function(){
       var cat = Animal.createNew();
       cat.name = "大毛";
       cat.makeSound = function(){ alert("喵喵喵"); };
       return cat;
     }
 };
登录后复制

   

立即学习Java免费学习笔记(深入)”;

  这样得到的Cat实例,就会继承Animal类。

var cat1 = Cat.createNew();
cat1.sleep(); // 睡懒觉
登录后复制

   

立即学习Java免费学习笔记(深入)”;

3. 私有属性和私有方法

  在createNew()方法中,只要不是定义在cat对象上的方法和属性,都是私有的。

var Cat = {
    createNew: function(){
      var cat = {};
      var sound = "喵喵喵";//私有属性
      cat.makeSound = function(){ 
     alert(sound); 
    };
      return cat;
    }
};
登录后复制

   

立即学习Java免费学习笔记(深入)”;

上例的内部变量sound,外部无法读取,只有通过cat的公有方法makeSound()来读取。

var cat1 = Cat.createNew();
alert(cat1.sound); // undefined
登录后复制

   

立即学习Java免费学习笔记(深入)”;

4. 数据共享

  有时候,我们需要所有实例对象,能够读写同一项内部数据。这个时候,只要把这个内部数据,封装在类对象的里面、createNew()方法的外面即可。

var Cat = {
    sound : "喵喵喵",
    createNew: function(){
      var cat = {};
      cat.makeSound = function(){ alert(Cat.sound); };
      cat.changeSound = function(x){ Cat.sound = x; };
      return cat;
    }
};
登录后复制

   

立即学习Java免费学习笔记(深入)”;

  然后,生成两个实例对象:

var cat1 = Cat.createNew();
var cat2 = Cat.createNew();
cat1.makeSound(); // 喵喵喵
登录后复制

   

立即学习Java免费学习笔记(深入)”;

这时,如果有一个实例对象,修改了共享的数据,另一个实例对象也会受到影响。

cat2.changeSound("啦啦啦");
cat1.makeSound(); // 啦啦啦
登录后复制

  极简主义,看起来很美好,但是也有缺点,首先是不能使用instanceof 判断对象所属的类,"cat1 instanceof Cat"无法通过,另外,极简主义虽然摆脱了使用原型链的缺点(属性不能私有、创建、继承对象不够直观),但也暴露了没用原型链的弊端:每一次生成一个实例,都必须为重复的内容,多占用一些内存。

以上内容就是关于极简主义法编写JavaScript类知识,希望对大家的工作有帮助。

相关推荐:

JavaScript面向对象(极简主义法minimalist approach)_js面向对象

处理JavaScript异常的方法

JavaScript模拟三种方式实现封装及区别介绍

以上就是极简主义法完成JavaScript的封装和继承的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号