缘由

当我看到_Franky兄的微博的时候:

我觉得我有必要出来详细说说KMDjs到底有什么本质上的优势了,连教主_Franky貘吃馍香都不能理解他的好处,那么可想而知,在前端圈、或是全端圈、或是IT圈,能够理解KMDjs优势的码夫更加是屈指可数。

Why Namespace?

KMDjs是能方便组织Namespace,并且Class Base。针对namespace,我还专门集成可视化库至KMDjs方便查看Namespace Tree。那么Why Namespace?不用会死吗?答案是:不会。但,但是。我要开始念书了(摘自《C#基于工程化的实现与扩展》):

尴尬的现实状况:

是否有很好的命名空间规划是工程化代码与非工程化代码一个明显的区别。

尤其对于大型的组织而言,如果涉及的产品线、项目、公共平台很多,如何通过命名空间把所有的代码资源有效地组织起来,恐怕是实施项目前腰考虑的主要问题。作为一个树形体系,最好有组织级统一的分类标准,目的很明确----用的时候很容易找到。

无论如果,为了您所带领的团队现在做的工作在以后能更容易地被应用,或者仅仅为你自己的职业生涯好好“储蓄”,在动笔编写第一行程序之前,先规划好命名空间吧。

可参考的建议来自Design Guideline,示例代码如下:

<Company>.(<Product>|<Technology>)[.<Feature>][.<Subnamespace>]

例如:Microsoft.WindowPhone.DirectX

一个大型软件企业,总体命名空间的规划如下:

Company.Application

Company.Foundation

Company.Framework

Company.Utility

Company.Training

Application:代表项目或产品

Foundation:代表公共库,类似Enterprise  Library之类的公共基础库、基于企业设备和操作系统平台的通用的图形处理引擎等,但都是纯粹的Class Library,没有UI元素。

Framework:组织通用的框架,基于Foundation之上,面向某个开发领域补充的Class Library和控件,其本身不能独立运行,但完全可以集成在具体的项目或产品中,比如通用的授权框架,完全AJAX化的前后端组建、报表和打印中间件。

Utility:企业内部各种工具,比如现场故障排查工具、Dump和日志分析工具。

Training:完全面向培训用途,是对企业自身Application、Foundation、Framework(甚至Utility)使用的Examples。

当然这是作为C#的空间调用关系,如果仅是web前端的话,应当把CLR部分去掉,如下:

 

不论您最终如果定义命名空间,其实它体现的是您意志中对代码资源的规划。

Who Namespace?

其实早在KMDjs出现之前,google开发团队早就意识到了Namespace的重要性,就弄个类似的东西。不过实现极度蹩脚。那就是老早以前,其代码被喷无数,但依然大名鼎鼎的google-closure-library。比如打开其date.js,可以看到:

provide是暴露的东西,require是依赖的东西。

写那么多不累吗?从上面其实就可以体现Class Base的重要性,但是我会另开一文详细谈下Why Class ?

微软的winjs比google进步了不少,至少意识到了namespace和class的重要性:

 

但winjs还是被kmdjs甩开十条街,因为其没有从工程化的角度考虑问题。

如果你一辈子就切个页面写个焦点图或者打算一辈子切个页面写个焦点图,请无视命名空间,继续require,继续export,继续切页面,写焦点图,继续拿着刚好能糊口的薪水,继续过着买两部iPhone6就月光的日子,庸庸碌碌得打发完一辈子宝贵的时光。

弃暗投明

再给自己一次重生的机会,转生入口:https://github.com/kmdjs/kmdjs

AMD and CMD are dead之Why Namespace?的更多相关文章

  1. AMD and CMD are dead之KMD规范

    What's KMD? 乱世出英雄,KMD名字的由来充满了杀气. Kill AMD and CMD KMD为替代混乱的AMD和CMD世界而生,一统天下.或者让这个混乱的世界更加混乱,导致: KMD A ...

  2. AMD and CMD are dead之js模块化黑魔法

    var define, require, define2, require2; typeof JSON != "object" && (JSON = {}), fu ...

  3. AMD and CMD are dead之KMDjs集成Blob一键下载全部build包

    更新 不zuo,[A/C]MD就不会死,所以kmdjs赢来来其伟大的版本0.0.6,该版本主要的更新有: 移除去了kmdjs.get(..).then的支持,只支持kmdjs.get(-,functi ...

  4. AMD and CMD are dead之KMD.js之懒

    缘由 "懒"在软件设计中,有着重大的意义.最常见的两种"懒",便是: 懒得计算 懒得加载 "懒得计算"常见于服务器端: 比如Multipla ...

  5. AMD and CMD are dead之KMD.js版本0.0.2发布

    更新 正式从UglifyJS切换至UglifyJS2 增加依赖可视化功能 压缩代码更加方便 统一风格:如main的class名也不能省略 优化了kmdjs管道 修复了无数bug 通过src开启debu ...

  6. AMD and CMD are dead之KMDjs内核之分号

    在老版本的kmdjs中,强制了分号的要求.但是总感觉不爽,因为在开发Ket - Kmdjs Extension Tools的时候,总需要导入一些开源的库,然后痛苦就来了,总是报错,一查,就是缺少分号! ...

  7. AMD and CMD are dead之KMDjs内核之依赖分析

    有人说js中有三座大三:this.原型链和scope tree,搞懂了他们就算是js成人礼.当然还有其他不同看法的js成人礼,如熟悉js的:OOP.AP.FP.DOP.AOP.当然还听说一种最牛B的j ...

  8. AMD and CMD are dead之KMDjs在JS工程化的努力

    总览 kmdjs发布了最接近最终版本的0.0.4版本https://github.com/kmdjs/kmdjs,你已经完全可以在项目中使用.我已经无法用语言形容其完美程度.借用我发的微博:   模块 ...

  9. AMD and CMD are dead之JS工程化终极解决方案KMD.js版本0.0.1发布

    回顾 经过两天晚上疯狂的开发调试,伴随着大量掉落的头发和酸痛的颈椎,KMD.js赢来了第一个稳定版本.在此期间KMD规范也有所修改和完善. 这两天主要完成的功能有: 按需加载 版本控制 模块管理 便捷 ...

随机推荐

  1. LINQ系列:Linq to Object投影操作符

    投影是指在将序列中的元素转换为一个自定义形式的操作.投影操作符Select和SelectMany用于选择出赋予了适当功能的值.SelectMany操作符可以处理多个集合. LINQ表达式语法: 1. ...

  2. Linq语法详细

    闲言碎语 近期比较忙,但还是想写点什么,就分享一些基础的知识给大家看吧,希望能帮助一些linq新手,如果有其它疑问,可以进右上角群,进行交流探讨,谢谢. 开门见山 读这篇文章之前,我先说下,每一种搜索 ...

  3. html5的audio在safari(windows)中无效

    因为mac下的safari不会有这样的问题(OSX默认都装的有QuickTime),而windows下用safari的比例实在小不用考虑. apple算是偷了一个小懒.而所谓的需要quicktime并 ...

  4. sizzle分析记录:关于querySelectorAll兼容问题

    querySelector和querySelectorAll是W3C提供的新的查询接口 目前几乎主流浏览器均支持了他们.包括 IE8(含) 以上版本. Firefox. Chrome.Safari.O ...

  5. MVC4做网站后台:用户管理 ——用户组

    用户管理这块包含用户和用户组两部分. 用户组包括浏览 用户组列表,添加.修改.删除用户组等.按照前面思路系统是依据用户组来判断用户权限的,用户组的最主要目的是划分权限.权限这块以后单独在做. 下面实现 ...

  6. 创建第一个 vlan network "vlan100" - 每天5分钟玩转 OpenStack(94)

    上一节我们在 ML2 配置中 enable 了 vlan network,今天将创建 vlan100 并讨论底层网络变化. 打开菜单 Admin -> Networks,点击 “Create N ...

  7. C# 对象锁——Monitor

    Monitor里边有一些static方法,可以用于在对象上获取同步锁,来进行一些进程同步控制操作 用法及注意点如下: using System; using System.Collections.Ge ...

  8. iOS开发之SQLite-C语言接口规范(一)——Ready And Open Your SQLite

    为什么要搞一搞SQLite的C语言接口规范呢? 因为在做iOS开发中难免会遇到操作数据库的情况,你可以使用第三方的FMDB等,或者使用CoreData.但我们还是有必要去搞清楚如何去使用SQLite的 ...

  9. Objective-C中的集合类

    下面详细的介绍Objective-C中的集合类以及每个集合类的用法,学过其他面向对象编程语言的小伙伴们看到OC的集合类会有种莫名的亲切感,理解起来问题不大,可以类比Java中的集合类去学习. 在Obj ...

  10. geotrellis使用初探

    最近,单位领导要求我研究一下geotrellis(GITHUB地址:https://github.com/geotrellis/geotrellis,官网http://geotrellis.io/), ...