命名空间:

  • 优点:可以解决命名混乱和第三方冲突;
  • 缺点:长嵌套导致更长的查询时间;更多的字符;
  • 通用命名空间函数:
    var MYAPP = MYAPP || {};
    MYAPP.namespace = function (ns_string) {
    var parts = ns_string.split('.');
    parent = MYAPP; if(parts[0] === 'MYAPP') {
    parts = parts.slice(1);
    }
    for(var i = 0; i < parts.length; i++) {
    if(typeof parent[parts[i]] === 'undefined') {
    parent[parts[i]] = {};
    }
    parent = parent[parts[i]];
    }
    return parent;
    }
    var module2 = MYAPP.namespace('MYAPP.modules.module2');

声明依赖关系:虽然已经进行了模块化命名,但再声明依赖能更优化

如对于:MYAPP, MYAPP.util.Event, MYAPP.util.Dom;
//在一个函数或模块顶部进行声明 var myFunc = function() {
var event = MYAPP.util.Event;
var dom = MYAPP.util.Dom;
................
}

解析局部变量的速度比解析全局变量快;

私有属性:

  • 私有属性和特权方法:构造函数方法

    function Gadget() {
    var name = 'iPod';
    this.getName = function () {
    return name;
    }
    }

    注意,如果私有属性设置是一个对象,且只读,那么不要将它直接返回,而是返回其浅复制后的副本;  

  • 私有属性:对象/匿名即时调用函数
    var myobj = (function () {
    var name = 'my';
    return {
    getName: function () {
    return name;
    }
    }
    }()); myobj.getName();
  • 私有属性:原型   如果是所有创建对象都需要的私有属性,可以设置到原型中
    Gadget.prototype = (function () {
    var browser = 'Mobile Webkit';
    return {
    getBrowser: function () {
    return browser;
    }
    }
    })

模块模式:

  • 组合:

    • 命名空间
    • 即时函数
    • 私有和特权成员
    • 声明依赖
  • 例子
    var MYAPP = {};
    MYAPP.namespace = function (ns_string) {
    var parts = ns_string.split('.');
    parent = MYAPP; if(parts[0] === 'MYAPP') {
    parts = parts.slice(1);
    }
    for(var i = 0; i < parts.length; i++) {
    if(typeof parent[parts[i]] === 'undefined') {
    parent[parts[i]] = {};
    }
    parent = parent[parts[i]];
    }
    return parent;
    };
    MYAPP.namespace('MYAPP.utilities.array');
    MYAPP.utilities.array = (function () {
    //依赖
    var uobj = MYAPP.utilities.object,
    ulang = MYAPP.utilities.lang,
    //私有属性
    array_string= '[object Array]',
    ops = Object.prototype.toString,
    //...
    //私有方法
    inArray = function (needle, haystack) {
    for(var i = 0, max = haystack.length; i < max; i++) {
    if(haystack[i] === needle) {
    return true;
    }
    }
    },
    isArray = function (a) {
    return ops.call(a) === array_string;
    }; //可选的一次性初始化过程 //公有API
    return {
    inArray:inArray,
    isArray:isArray,
    //...
    }
    })();
  • 例子:使用构造函数
    MYAPP.namespace('MYAPP.utilities.Array');
    MYAPP.utilities.Array = (function () {
    //依赖
    var uobj = MYAPP.utilities.object,
    ulang = MYAPP.utilities.lang,
    //私有属性和方法
    Constr; //可选的一次性初始化过程
    //.... //公有API-构造函数
    Constr = function(o) {
    this.elements = this.toArray(o);
    };
    //公有API-原型
    Constr.prototype = {
    constructor: MYAPP.utilities.Array,
    version: '2.0',
    toArray: function (obj) {
    for (var i = 0, a = [], len = obj.length; i < len; i++) {
    a[i] = obj[i];
    }
    return a;
    }
    }
    //返回要配置给新空间的构造函数
    return Constr;
    })();
    var arr = new MYAPP.utilities.Array(['a','b']);
  • 将全局变量导入模块中
    MYAPP.utilities.module = (function (app, global) {})(MYAPP, this);
    

      

javascript优化--06模式(对象)01的更多相关文章

  1. javascript优化--10模式(设计模式)01

    单体模式:保证一个特定类仅有一个实例;即第二次使用同一个类创建新对象时,应该得到与第一个所创建对象完全相同对象: 在JS中,可以认为每次在使用对象字面量创建对象的时候,实际上就在创建一个单体: 当使用 ...

  2. javascript优化--07模式(对象)02

    沙箱模式: 解决空间命名模式的几个缺点: 命名空间模式中无法同时使用一个应用程序或库的两个版本运行在同一个页面中,因为两者需要相同的全局符号: 以点分割,需要输入更长的字符,解析时间也更长: 全局构造 ...

  3. javascript优化--08模式(代码复用)01

    优先使用对象组合,而不是类继承: 类式继承:通过构造函数Child()来获取来自于另一个构造函数Parent()的属性: 默认模式:子类的原型指向父类的一个实例 function inherit(C, ...

  4. javascript优化--13模式1(DOM和浏览器模式)

    注意分离: 通过将CSS关闭来测试页面是否仍然可用,内容是否依然可读: 将JavaScript关闭来测试页面仍然可以执行正常功能:所有连接是否正常工作:所有的表单是否可以正常工作: 不使用内联处理器( ...

  5. javascript优化--05模式(函数)

    回调函数模式: 基本例子: var findNodes = function (callback) { ...................... if (typeof callback !== ' ...

  6. javascript优化--11模式(设计模式)02

    策略模式 在选择最佳策略以处理特定任务(上下文)的时候仍然保持相同的接口: //表单验证的例子 var data = { firs_name: "Super", last_name ...

  7. javascript优化--09模式(代码复用)02

    原型继承 ://现代无类继承模式 基本代码: var parent = { name : "Papa" } var child = object(parent); function ...

  8. JavaScript基础06——Math对象和日期对象

    内置对象-Math:  Math对象用于执行 数学任务,Math 不像 Date 和 String 那样是对象的类,因此没有构造函数Math().无需创建,直接把Math当成对象使用,就可以调用其所有 ...

  9. javascript优化--12模式(设计模式)03

    观察者模式 通过创建一个可观察的对象,当发生一个感兴趣的事件时将该事件通告给所有观察者,从而形成松散的耦合 订阅杂志 //发布者对象 var publisher = { subscribers: { ...

随机推荐

  1. C# Window Service详解

    Windows Service这一块并不复杂,但是注意事项太多了,网上资料也很凌乱,偶尔自己写也会丢三落四的.所以本文也就产生了,本文不会写复杂的东西,完全以基础应用的需求来写,所以不会对Window ...

  2. 推荐两款Xcode插件:KSImageNamed & ColorSense

    之前没怎么接触过Xcode插件,最近发现有人给Xcode做了一些方便编程的插件.今天就推荐两个我个人认为比较好的. 1.KSImageNamed 网站地址 KSImageNamed是一款方便填写图片文 ...

  3. VS2008+Qt+助手 智能提示不显示、Qt关键字不高亮的解决办法【已解决】

    笔者使用的开发环境是VS2008+Qt4.8.5+VAssistX,有时候会出现代码关键字不能高亮显示,并且助手的智能提示不显示.问题如下 解决的办法是在助手的选项中设置其搜索路径,助手的设置通过VS ...

  4. RemObjects SDK Source For Delphi XE7

    原文:http://blog.csdn.net/tht2009/article/details/39545545 1.目前官网最新版本是RemObjects SDK for Delphi and al ...

  5. 最长公共子串 NYOJ 36

    http://acm.nyist.net/JudgeOnline/problem.php?pid=36 最长公共子序列 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 ...

  6. MongoDB概述&语法

    Nosql DB 这是一个非关系型数据库. 通常我们的数据库有三类:  关系型数据库(RDBMS),联机分析处理数据库(OLAP),和菲关系型数据库(NoSql). MongoDB属于第三种,而且是一 ...

  7. python代码中使用settings

    在具体的Django应用中,通过引入 django.conf.settings 使用配置,例: from django.conf import settings settings.configure( ...

  8. 如何利用phpize在生产环境中为php添加新的扩展php-bcmath

    在日常的开发当中,随着开发的功能越来越复杂.对运行环境的要求也就随着需求的变化需要不断地更新和变化.一个在线的生产系统不可能一开始就满足了所有的运行依赖,因此动态地添加依赖就显得比较必要了.如果你的应 ...

  9. 用RPM包安装MySQL的默认安装路径问题

    在安装PHP时候要对一些配置选项进行设置,其中就有:--with-mysql[=DIR]:包含MySQL扩展,[=DIR]指定mysql安装目录,省略[=DIR]则为默认位置/usr--with-my ...

  10. libavcodec/dxva2.h:40:5: error: unknown type name 'IDirectXVideoDecoder'

    gcc 4.9.2 编译 ffmpeg-git-1aeb88b 是出现如下错误 > FFmpeg fails to make with: > > CC libavcodec/dxva ...