`
sjpsega
  • 浏览: 300394 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

javascript中的封装

    博客分类:
  • web
 
阅读更多

最近的一个小任务,需要写一个jQuery的插件,但是根据jQuery官方的文档http://docs.jquery.com/Plugins/Authoring写得有点头晕,主要是对this对象的理解不够深刻和js基础薄弱引起的。

故又翻开了书本,看了经典了《Javascript高级程序设计》、《JavaScript设计模式》,之前囫囵吞枣看过一遍,印象已经不深了,今天又看了一遍,做一下笔记。

 

封装简单地说就是让外界只能访问对象的共有变量和函数,隐藏细节和数据。

js中有三种方法创建对象,分别为门户大开型、用命名规范区分私有变量、闭包创建真正的私有变量三种。

1.门户大开型,是实现对象的最基础的方法,所有方法与变量都是共有的外界可以访问。

 

                var Book = function(name){
                    if(this.check(name)){
                        console.log("error");
                        throw new Error("name null");
                    }
                    this.name = name;
                }
                Book.prototype = {
                    check:function(name){
                        if(!name){
                            return true;
                        }
                    },
                    getName:function(){
                        return this.name;
                    }
                }

                var book = new Book("哈哈");
                //output:哈哈 哈哈
                console.log(book.name,book.getName());

这个例子是门户大开型的典型,外界能直接访问对象的属性和方法。可以注意到属性和变量都有"this"来创建。

 

2.用命名规范区分私有变量,该方法是门户大开型的优化版本,只不过是在私有变量或方法前面用"_"区分,如果有程序员有意使用_getName()的方法来调用方法,还是无法阻止的,不是真正地将变量隐藏。

 

3.闭包创建真正的私有变量,该方法利用js中只有函数具有作用域的特性,在构造函数的作用域中定义相关变量,这些变量可以被定义域该作用域中的所有函数访问。

 

                var Book2 = function(name){
                    if(check(name)){
                        console.log("error");
                        throw new Error("name null");
                    }
                    name = name;
                    function check(name){
                        if(!name){
                            return true;
                        }
                    }
                    this.getName = function(){
                        return name;
                    }
                }
                Book2.prototype = {
                    display:function(){
                        //无法直接访问name
                        return "display:"+this.getName();
                    }
                }
                var book2 = new Book2("哈哈");
                //output:undefined "哈哈" "display:哈哈"
                console.log(book2.name,book2.getName(),book2.display());

 可以看到,这个例子中的结果,直接访问name会返回undefined的结果。可以看到这个例子与门户大开型的区别,门户大开型中的变量使用"this"来创建,而这个例子中使用var来创建,check函数也是如此,使得name与check函数只能在构造函数的作用域中访问,外界无法直接访问。

该方法解决了前两种方法的问题,但是也有一定的弊端。在门户大开型对象创建模式中,所有方法都创建在原型对象中,因此不管生成多少对象实例,这些方法在内存中只存在一份,而采用该方法,每生成一个新的对象都会为每个私有变量和方法创建一个新的副本,故会耗费更多的内存。

 

相关阅读:

学习javascript闭包

Javascript继承机制的设计原理

分享到:
评论

相关推荐

    Javascript中封装window.open解决不兼容问题

    对window.open进行封装, 使其更好用, 且更兼容, 很多人说window.open不兼容,其实不是, 因为不能直接执行, 必须通过用户手动触发才行;看代码: 代码如下 var openWindow = function(url, options) { var str = ""; ...

    国内外 JavaScript 经典封装

    "国内外 JavaScript 经典封装" 涵盖了JavaScript编程中的各种高效、实用的代码封装技巧和库,这些技巧和库大大提高了开发效率,简化了复杂任务的处理。下面,我们将深入探讨这些经典封装所涉及的知识点。 1. **面向...

    国内外javascript经典封装

    通过学习和运用这些经典的JavaScript封装技术,开发者不仅能提升代码质量,还能跟上技术发展趋势,确保项目在未来的可扩展性和兼容性。同时,理解并熟练掌握封装原则,也是成为一名优秀JavaScript开发者的重要一步。

    javaScript中封装的各种写法示例(推荐)

    在JavaScript编程中,封装是面向对象编程的核心概念之一,它涉及将数据和操作数据的方法捆绑在一起,形成一个独立的对象,目的是隐藏对象的实现细节,对外提供简洁的接口。封装能够提高代码的可维护性、可重用性以及...

    Javascript中的封装与继承

    在这个文档中,我们将深入探讨JavaScript中的封装和继承这两个核心概念,帮助你更好地理解和应用这些知识。 封装是面向对象编程的基本原则之一,它涉及到如何组织和保护代码,以实现数据隐藏和功能模块化。在...

    Javascript经典封装代码

    "JavaScript经典封装代码"集合了开发者们在实践中总结出的一些高效、实用的代码片段,旨在提高开发效率,优化代码结构,增强程序的可读性和可维护性。下面,我们将深入探讨这些经典封装代码背后的原理和应用场景。 ...

    javascript 经典封装

    在这个压缩包中,包含了10个相关的RAR子文件,可能是关于JavaScript封装技术的不同示例或者教程。 1. **对象封装**:在JavaScript中,对象可以用来封装数据和功能。通过创建具有属性和方法的对象,我们可以更好地...

    JavaScript对象封装与单元测试.pdf

    在JavaScript对象封装中,我们可以使用构造函数来初始化对象的状态,使用setter和getter来控制对象的属性,使用methods来定义对象的行为。这样可以使代码更加模块化和易于理解。 JavaScript对象封装与单元测试是...

    JavaScript 封装库:BETA 4.0 版

    JavaScript封装库是一种预先编写好的JavaScript代码集合,它提供了各种函数、类或模块,供开发者在自己的项目中直接使用或扩展。这些库通常包括对DOM操作、动画效果、事件处理、数据管理等功能。JavaScript封装库的...

    javascript中如何实现封装,继承和多态

    javascript中如何实现封装,继承和多态

    javascript 封装技术

    全面介绍如何用OO方式封装Javascript,高手必看。

    javascript 消息提示封装文件

    在JavaScript中,封装意味着将特定的功能或行为打包到一个独立的模块中,以便于在项目的不同部分重复使用。对于消息提示来说,这意味着创建一个函数或类,该函数或类负责生成、显示和管理各种类型的消息,如警告、...

    asp.net开发常用javascript函数封装(c#)

    本文将详细讲解如何在C#中封装常用的JavaScript函数,并探讨这些函数在实际开发中的应用。 一、JavaScript函数封装的意义 在ASP.NET项目中,为了提高代码复用性,降低维护成本,我们常常会将一些常用的功能封装成...

    Javascript效果封装类(都是国外高手写的)

    JavaScript是一种广泛应用于...它们可以帮助开发者掌握如何使用JavaScript封装功能,提高代码质量,并学习各种前端特效的实现原理。通过深入理解并实践这些示例,可以提升你的前端开发技能,使你在项目中更加游刃有余。

    Javascript Cookie操作类的封装

    在JavaScript中,Cookie是一种在客户端存储少量数据的机制,它对于网页应用的用户状态管理和临时存储信息具有重要作用。本文将详细讲解如何封装一个Cookie操作类,实现对Cookie的增删改查功能。 首先,理解Cookie的...

    javascript经典封装,以及实现的图片效果

    在本主题中,“javascript经典封装”指的是将常用的JavaScript功能或方法进行模块化封装,以提高代码的可重用性和可维护性。而“js实现的10个图片效果”则是指利用JavaScript来控制和改变网页中的图像,创造出各种...

    原生javascript自己封装的一些常用小方法

    原生javascript自己封装的一些常用小方法

    国内外JavaScript经典封装

    综上所述,这些JavaScript经典封装案例覆盖了从基本的浏览器兼容性修复到复杂的交互设计,展示了JavaScript在网页开发中的强大能力和灵活性。通过学习和应用这些技巧,开发者可以提升他们的JavaScript技能,创造出更...

Global site tag (gtag.js) - Google Analytics