高程之最佳实践

1、可维护性

  • 可理解性、
  • 直观性、
  • 可适应性、
  • 可扩展性、
  • 可调式性

1.1 代码约定:

1. 可读性:

一般来说和代码格式有关系
需要添加注释的地方:

  • 函数和方法:每个函数或者是方法都应该包含一个注释,描述其目的和用于完成任务所有可能使用的算法,参数代表什么以及函数是否有返回值
  • 大段代码:用于完成单个任务的多行代码应该在前边放一个描述任务的注释
  • 复杂的算法:如果使用一种独特的方式解决莫个问题,要注意注释中解释你是如何做的
  • Hack :

2 变量和函数命名:

  • 变量名为名词:car person
  • 函数名以动词开头: getName 返回boolean的函数以is开头
  • 变量函数都要合乎逻辑,不要担心长度

3 变量类型透明

第一种方式是:初始化;
var found = false;
第二种方法是匈牙利标记发来指定变量类型。匈牙利在变量名之前加一个或多个字符来表示数据类型。
var bFound;//boolean
var iCount;//int
第三种 类型注释:
var found /:Boolean/ = false;

1.2 松散耦合

只要某个部分的代码过于依赖另一个部分,代码就是耦合过紧,难于维护

对象直接引用另一个对象,并且当修改其中一个的同时,需要修改另外一个,紧密的耦合的软件难于维护需要经常重写

1、解耦html/javascript
分开来写
2、解耦css/javascript
js改变class而不改变style
3、解耦应用逻辑/事件处理程序

以下是一些混合在一起的方法

function handleKeyPress(event) {
    event = EventUtil.getEvent(event);
    if(event.keyCode ==13){
        var target = EventUtil.getTarget(event);
        var value = 5*parseFloat(target.value);
        if(value>10){
            document.getElementById("error-msg").style.display = "block";
        }
    }
}

然后把业务和事件拆分开看看


function handleKeyPress(event) {
    event = EventUtil.getEvent(event);
    if(event.keyCode ==13){
        var target = EventUtil.getTarget(event);
        validateValue(target.value)
    }
}
function validateValue(value) {
    value = 5*value;
    if(value>10){
        document.getElementById("error-msg").style.display = "block";
    }
}

以下是松散耦合的原则:

  • event对象不当成参数传
  • 任何可以在因用户层面的动作都应该可以在不执行任何时间处理程序的情况下进行
  • 任何事件处理程序都应该处理事件,然后将处理转交给应用逻辑

1.3 实战:

1、尊重对象所拥有权
2、避免全局量
3、避免与null进行比较,如果遇到一个与null比较的代码,尝试一下的技术:
如果值应该为一个引用类型,用instanceof
如果值应该是一个基本类型,用typeof检测其类型
如果是希望对象包含摸个特定的方法名,typeo操作符确保指定名字存在于对象上

4、使用常量
将数据和使用它的逻辑进行分离,
1、重复值 任何再多出用到的值,都应该抽取为一个常量。
2、用户界面字符串--任何用于显示给用户的字符串,都硬掰抽取出来以方便国际化
3、URLs-- 资源位置容易变,所以需要公共地方存放
4、任意可能会改变的值

2、性能

2.1 注意作用域

只要能减少作用域链上消耗的时间,就能增加脚本的整体性能
1、避免全局查找:比如频繁的调用document
2、避免with语句,with会创建自己的作用域。从而增加了其中执行的代码的作用域链的长度。

2.2 选择正确的方法:

1、 避免不必要的属性查找

注意:
数组的复杂度是O(1)而对象的空间复杂度是O(n);
所以一旦多次遇到对象的属性,应该将他们存放在局部变量中。
尽可能多的使用局部变量将睡醒查找替换为值查找

2、优化迭代

  1. for循环从大到小
  2. 简化终止条件
  3. 简化循环体
  4. 使用后测试循环,for while是前测试循环do-while是后测试循环,避免了终止的计算

3、展开循环
循环次数确定时候,消除循环,多次函数调用,往往更快,
4、避免出现双重解释
eval("alert('')");
new Function();
setTimeOut("",300);
5、性能的其他注意项:
原生的方法比较快:Math.各种方法比手写的算法快,因为js默认的方法是c/c++直接编译的
switch语句比ifelse快
位运算比任何布尔运算或者算术运算快

2.3最小化语句数:

1、多个变量申明,
var a=1,b=2,c=3这种
2、插入迭代值

一个语句完成两个语句的事情时候,用i++嵌套到语句中
3、使用数组和对象字面量

2.4优化DOM交互

最小化现场更新,使用innerHTML,使用时间代理,注意HTMLCollection的使用

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,493评论 18 399
  • importUIKit classViewController:UITabBarController{ enumD...
    明哥_Young阅读 3,757评论 1 10
  • 我不知道自己到底喜不喜欢猫。 看到了总想亲近,听到软媚的叫声骨头也实在是酥得厉害。但真要我抱起来,养在家里,又多少...
    水色小雏菊阅读 184评论 0 0
  • 这几天,关于里约奥运会的话题,开始成为大家茶余饭后的谈资。对于巴西“史上最不给力奥运会”的吐槽,或关于某国代表团因...
    蜘蜘纺阅读 122评论 0 0
  • 南方的高山追赶蓝天, 想用深邃的双眼 兑换永世的青春。 只因知道阳光偏爱人间, 温暖是天长地久的。 匆匆而逝的云呢...
    叶落晨曦阅读 196评论 0 3