奉献给JavaScript初学者的编写开发的七个细节


Posted in Javascript onJanuary 11, 2011

(1)简化代码
JavaScript定义对象和数组非常简单,我们想要创建一个对象,一般是这样写的:

var car = new Object(); 
car.colour = 'red'; 
car.wheels = 4; 
car.hubcaps = 'spinning'; 
car.age = 4;

下面的写法可以达到同样的效果:
var car = { 
colour:'red', 
wheels:4, 
hubcaps:'spinning', 

age:4 
}

后面的写法要短得多,而且你不需要重复写对象名称。

另外对于数组同样有简洁的写法,过去我们声明数组是这样写的:

var moviesThatNeedBetterWriters = new Array( 
'Transformers','Transformers2','Avatar','Indiana Jones 4' 
);

更简洁的写法是:
var moviesThatNeedBetterWriters = [ 
'Transformers','Transformers2','Avatar','Indiana Jones 4' 
];

对于数组,还有关联数组这样一个特别的东西。 你会发现很多代码是这样定义对象的:
var car = new Array(); 
car['colour'] = 'red'; 
car['wheels'] = 4; 
car['hubcaps'] = 'spinning'; 
car['age'] = 4;

这太疯狂了,不要觉得困惑,“关联数组”只是对象的一个别名而已。
另外一个简化代码的方法是使用三元运算符,举个例子:
var direction; 
if(x < 200){ 
direction = 1; 
} else { 
direction = -1; 
}

我们可以使用如下的代码替换这种写法:
var direction = x < 200 ? 1 : -1;

(2)使用JSON作为数据格式

伟大的Douglas Crockford发明了JSON数据格式来存储数据,你可以使用原生的javascript方法来存储复杂的数据而不需要进行任何额外的转换,例如:
var band = { 
"name":"The Red Hot Chili Peppers", 
"members":[ 
{ 
"name":"Anthony Kiedis", 
"role":"lead vocals" 
}, 
{ 
"name":"Michael 'Flea' Balzary", 
"role":"bass guitar, trumpet, backing vocals" 
}, 
{ 
"name":"Chad Smith", 
"role":"drums,percussion" 
}, 
{ 
"name":"John Frusciante", 
"role":"Lead Guitar" 
} 
], 
"year":"2009" 
}

你可以使用在JavaScript中直接使用JSON,甚至作为API返回的一种格式,这就是所谓的JSON ? P,在许多的API中被应用,例如:
<div id="delicious"></div><script> 
function delicious(o){ 
var out = '<ul>'; 
for(var i=0;i<o.length;i++){ 
out += '<li><a href="' + o[i].u + '">' + 
o[i].d + '</a></li>'; 
} 
out += '</ul>'; 
document.getElementById('delicious').innerHTML = out; 
} 
</script> 
<script src="http://feeds.delicious.com/v2/json/codepo8/javascript?count=15&callback=delicious"></script>

这里调用delicious 的Web服务获取最新书签,以JSON格式返回,然后将它们显示成无序列表的形式。
从本质上讲,JSON是用于描述复杂的数据最轻量级的方式,而且直接它运行在浏览器中。 你甚至可以在PHP中调用 json_decode()函数来使用它。
(3)尽量使用JavaScript原生函数
要找一组数字中的最大数,我们可能会写一个循环,例如:
var numbers = [3,342,23,22,124]; 
var max = 0; 
for(var i=0;i<numbers.length;i++){ 
if(numbers[i] > max){ 
max = numbers[i]; 
} 
} 
alert(max);

其实,不用循环可以实现同样的功能:
var numbers = [3,342,23,22,124]; 
numbers.sort(function(a,b){return b - a}); 
alert(numbers[0]);

而最简洁的写法是:
Math.max(12,123,3,2,433,4); // returns 433

你甚至可以使用Math.max来检测浏览器支持哪个属性:
var scrollTop= Math.max( 
doc.documentElement.scrollTop, 
doc.body.scrollTop 
);

如果你想给一个元素增加class样式,可能原始的写法是这样的:
function addclass(elm,newclass){ 
var c = elm.className; 
elm.className = (c === '') ? newclass : c+' '+newclass;

而更优雅的写法是:
function addclass(elm,newclass){ 
var classes = elm.className.split(' '); 
classes.push(newclass); 
elm.className = classes.join(' '); 
}

(4)事件委托
事件是JavaScript非常重要的一部分。我们想给一个列表中的链接绑定点击事件,一般的做法是写一个循环,给每个链接对象绑定事件,HTML代码如下:
<h2>Great Web resources</h2> 
<ul id="resources"> 
<li><a href="http://opera.com/wsc">Opera Web Standards Curriculum</a></li> 
<li><a href="http://sitepoint.com">Sitepoint</a></li> 
<li><a href="http://alistapart.com">A List Apart</a></li> 
<li><a href="http://yuiblog.com">YUI Blog</a></li> 
<li><a href="http://blameitonthevoices.com">Blame it on the voices</a></li> 
<li><a href="http://oddlyspecific.com">Oddly specific</a></li> 
</ul>

脚本如下:
// Classic event handling example 
(function(){ 
var resources = document.getElementById('resources'); 
var links = resources.getElementsByTagName('a'); 
var all = links.length; 
for(var i=0;i<all;i++){ 
// Attach a listener to each link 
links[i].addEventListener('click',handler,false); 
}; 
function handler(e){ 
var x = e.target; // Get the link that was clicked 
alert(x); 
e.preventDefault(); 
}; 
})();

更合理的写法是只给列表的父对象绑定事件,这样可行的原理在于事件是支持冒泡的,代码如下:
(function(){ 
var resources = document.getElementById('resources'); 
resources.addEventListener('click',handler,false); 
function handler(e){ 
var x = e.target; // get the link tha 
if(x.nodeName.toLowerCase() === 'a'){ 
alert('Event delegation:' + x); 
e.preventDefault(); 
} 
}; 
})();

(5)匿名函数
关于JavaScript的最头疼的事情之一是,它的变量没有特定的作用范围。 一般情况下,任何变量,函数,数组或对象都是全局性,这意味着在同一页上的其他脚本可以访问并覆盖它们。解决方法是把变量封装在一个匿名函数中。 例如,下面的定义将产生三个全局变量和和两个全局函数:
var name = 'Chris'; 
var age = '34'; 
var status = 'single'; 
function createMember(){ 
// [...] 
} 
function getMemberDetails(){ 
// [...] 
}

封装后如下:
var myApplication = function(){ 
var name = 'Chris'; 
var age = '34'; 
var status = 'single'; 
return{ 
createMember:function(){ 
// [...] 
}, 
getMemberDetails:function(){ 
// [...] 
} 
} 
}(); 
// myApplication.createMember() and 
// myApplication.getMemberDetails() now works.

这被称为单体模式,是JavaScript设计模式的一种,这种模式在YUI中用得非常多,改进的写法是:
var myApplication = function(){ 
var name = 'Chris'; 
var age = '34'; 
var status = 'single'; 
function createMember(){ 
// [...] 
} 
function getMemberDetails(){ 
// [...] 
} 
return{ 
create:createMember, 
get:getMemberDetails 
} 
}(); 
//myApplication.get() and myApplication.create() now work.

(6)代码可配置 你写的代码如果想让别人更容易进行使用或者修改,则需要可配置,解决方案是在你写的脚本中增加一个配置对象。要点如下:
1、在你的脚本中新增一个叫configuration的对象。
2、在配置对象中存放所有其它人可能想要去改变的东西,例如CSS的ID、class名称、语言等等。
3、返回这个对象,作为公共属性以便其它人可以进行重写。

(7)代码兼容性

兼容性是初学者容易忽略的部分,通常学习Javascript的时候都是在某个固定的浏览器中进行测试,而这个浏览器很有可能就是IE,这是非常致命的,因为目前几大主流浏览器中偏偏IE对标准的支持是最差的。最终用户看到的结果也许就是,你写的代码在某个浏览器无法正确运行。你应该把你的代码在主流的浏览器中都测试一下,这也许很费时间,但是应该这样做。
原文来自:Seven JavaScript Things I Wish I Knew Much Earlier In My Career)

Javascript 相关文章推荐
JavaScript 获取用户客户端操作系统版本
Aug 25 Javascript
用jquery与css打造个性化的单选框和复选框
Oct 20 Javascript
控制台报错object is not a function的解决方法
Aug 24 Javascript
javascript字符串循环匹配实例分析
Jul 17 Javascript
浅谈js的html元素的父节点,子节点
Aug 06 Javascript
Bootstrap的class样式小结
Dec 01 Javascript
bootstrap实现的自适应页面简单应用示例
Mar 09 Javascript
javascript完美实现给定日期返回上月日期的方法
Jun 15 Javascript
深入浅析Node.js单线程模型
Jul 10 Javascript
JavaScript中使用import 和require打包后实现原理分析
Mar 07 Javascript
Node.js模拟发起http请求从异步转同步的5种用法
Sep 26 Javascript
Angular CLI 使用教程指南参考小结
Apr 10 Javascript
从盛大通行证上摘下来的身份证验证js代码
Jan 11 #Javascript
javascript 设为首页与加入收藏兼容多浏览器代码
Jan 11 #Javascript
javascript获取当前日期时间及其它操作函数
Jan 11 #Javascript
JavaScript中URL编码函数代码
Jan 11 #Javascript
Jquery跨域获得Json时invalid label错误的解决办法
Jan 11 #Javascript
JS无限树状列表实现代码
Jan 11 #Javascript
jQuery UI的Dialog无法提交问题的解决方法
Jan 11 #Javascript
You might like
php 结果集的分页实现代码
2009/03/10 PHP
php中获得视频时间总长度的另一种方法
2011/09/15 PHP
如何利用php array_multisort函数 对数据库结果进行复杂排序
2013/06/08 PHP
基于linnux+phantomjs实现生成图片格式的网页快照
2015/04/15 PHP
浅谈PHP中的
2016/04/23 PHP
php安装dblib扩展,连接mssql的具体步骤
2017/03/02 PHP
预加载css或javascript的js代码
2010/04/23 Javascript
jQuery-onload让第一次页面加载时图片是淡入方式显示
2012/05/23 Javascript
ScrollDown的基本操作示例
2013/06/09 Javascript
JavaScript中具名函数的多种调用方式总结
2014/11/08 Javascript
jQuery实现鼠标点击弹出渐变层的方法
2015/07/09 Javascript
AngularJS的一些基本样式初窥
2015/07/27 Javascript
前端html中jQuery实现对文本的搜索功能并把搜索相关内容显示出来
2017/11/14 jQuery
JS 音频可视化插件Wavesurfer.js的使用教程
2018/10/31 Javascript
QML实现圆环颜色选择器
2019/09/25 Javascript
[44:10]2018DOTA2亚洲邀请赛 4.5 淘汰赛 EG vs VP 第一场
2018/04/06 DOTA
Python中random模块用法实例分析
2015/05/19 Python
python实现的简单抽奖系统实例
2015/05/22 Python
对numpy中数组元素的统一赋值实例
2018/04/04 Python
Python后台开发Django的教程详解(启动)
2019/04/08 Python
python3 webp转gif格式的实现示例
2019/12/10 Python
Pycharm和Idea支持的vim插件的方法
2020/02/21 Python
Python实现SMTP邮件发送
2020/06/16 Python
python代数式括号有效性检验示例代码
2020/10/04 Python
HTML5 虚拟键盘出现挡住输入框的解决办法
2017/02/14 HTML / CSS
澳洲的UGG雪地靴超级市场:Uggs.com.au
2020/04/06 全球购物
北京泡泡网网络有限公司.net面试题
2012/07/17 面试题
文员自我评价怎么写
2013/09/19 职场文书
遗体告别仪式答谢词
2014/01/23 职场文书
《与象共舞》教学反思
2014/02/24 职场文书
办公用房租赁协议书
2014/11/29 职场文书
检讨书大全
2015/01/27 职场文书
2014年底个人工作总结
2015/03/10 职场文书
教师师德工作总结2015
2015/07/22 职场文书
MySQL8.0.18配置多主一从
2021/06/21 MySQL
Redis实现订单过期删除的方法步骤
2022/06/05 Redis