搜索
首页web前端js教程JavaScript初学者应注意的七个细节

每种语言都有它特别的地方,对于JavaScript来说,使用var就可以声明任意类型的变量,这门脚本语言看起来很简单,然而想要写出优雅的代码却是需要不断积累经验的。本文利列举了JavaScript初学者应该注意的七个细节,与大家分享。 

(1)简化代码

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

1 var
 
car = 
new
 
Object();  
2 car.colour = 
red
;  
3 car.wheels = 4;  
4 car.hubcaps = 
spinning
;  
5 car.age = 4;

下面的写法可以达到同样的效果: 

1 var
 
car = {  
2     
colour:
red
,  
3     
wheels:4,  
4   hubcaps:
spinning
,  
5   age:4  
6 }

后面的写法要短得多,而且你不需要重复写对象名称。注意大括号后面不要加分号,否则IE中会出错。 

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

1 var
 
moviesThatNeedBetterWriters = 
new
 
Array(  
2   
Transformers
,
Transformers2
,
Avatar
,
Indiana Jones 4 
3 );

更简洁的写法是:  

1 var
 
moviesThatNeedBetterWriters = [  
2   
Transformers
,
Transformers2
,
Avatar
,
Indiana Jones 4 
3 ];

对于数组,还有关联数组这样一个特别的东西。 你会发现很多代码是这样定义对象的:

1 var
 
car = 
new
 
Array();  
2 car[
colour
] = 
red
;  
3 car[
wheels
] = 4;  
4 car[
hubcaps
] = 
spinning
;  
5 car[
age
] = 4;

这太疯狂了,不要觉得困惑,“关联数组”只是对象的一个别名而已。 另外一个简化代码的方法是使用三元运算符,举个例子:

1 var
 
direction;  
2 if
(x < 200){
3
direction = 1;
4 }
else

{
5
direction = -1;
6 }

我们可以使用如下的代码替换这种写法:

1 var

direction = x < 200 ? 1 : -1;

(2)使用JSON作为数据格式 伟大的Douglas Crockford发明了JSON数据格式来存储数据,你可以使用原生的javascript方法来存储复杂的数据而不需要进行任何额外的转换,例如:

01 var

band = {
02
"name"
:
"The Red Hot Chili Peppers"
,
03
"members"
:[
04
{
05
"name"
:
"Anthony Kiedis"
,
06
"role"
:
"lead vocals"
07
},
08
{
09
"name"
:
"Michael Flea Balzary"
,
10
"role"
:
"bass guitar, trumpet, backing vocals"
11
},
12
{
13
"name"
:
"Chad Smith"
,
14
"role"
:
"drums,percussion"
15
},
16
{
17
"name"
:
"John Frusciante"
,
18
"role"
:
"Lead Guitar"
19
}
20
],
21
"year"
:
"2009"
22 }

你可以使用在JavaScript中直接使用JSON,甚至作为API返回的一种格式,这就是所谓的JSON ? P,在许多的API中被应用,例如:

01 <
div

id
=
"delicious"
>div
><
script
>  
02 function delicious(o){  
03   
var out = <
ul
>;  
04   
for(var i=0;i<
o.length
;i++){
05
out +=

  • <
    a

    href
    =
    " + o[i].u + "
    > +  
    06            
    o[i].d + a
    >li
    >;  
    07   
    }  
    08   
    out += ul
    >;  
    09   
    document.getElementById(delicious).innerHTML = out;  
    10 }  
    11 script
    >  
    12 <
    script

    src
    =
    "http://feeds.delicious.com/v2/json/codepo8/javascript?count=15&callback=delicious"
    >script
    >

    这里调用delicious 的Web服务获取最新书签,以JSON格式返回,然后将它们显示成无序列表的形式。 从本质上讲,JSON是用于描述复杂的数据最轻量级的方式,而且直接它运行在浏览器中。 你甚至可以在PHP中调用 json_decode()函数来使用它。

    1 "FONT-FAMILY: 宋体; mso-ascii-font-family: Times New Roman; mso-hansi-font-family: Times New Roman"
    >"FONT-SIZE: 14pt"
    >(3)
    "FONT-SIZE: 14pt"
    >"FONT-FAMILY: 宋体; mso-ascii-font-family: Times New Roman; mso-hansi-font-family: Times New Roman"
    >尽量使用
    "FONT-FAMILY: Times New Roman"

    face=
    "Times New Roman"
    >Javascript
    "FONT-FAMILY: 宋体; mso-ascii-font-family: Times New Roman; mso-hansi-font-family: Times New Roman"
    >原生函数
    "FONT-FAMILY: 宋体; mso-ascii-font-family: Times New Roman; mso-hansi-font-family: Times New Roman"
    >

     

    要找一组数字中的最大数,我们可能会写一个循环,例如:

    1 var
     
    numbers = [3,342,23,22,124];  
    2 var
     
    max = 0;  
    3 for
    (
    var
     
    i=0;i4
    if
    (numbers[i] > max){  
    5     
    max = numbers[i];  
    6   
    }  
    7 }  
    8 alert(max);

    其实,不用循环可以实现同样的功能:

    1 var
     
    numbers = [3,342,23,22,124];  
    2 numbers.sort(
    function
    (a,b){
    return
     
    b - a});  
    3 alert(numbers[0]);

    而最简洁的写法是:

    1 Math.max(12,123,3,2,433,4); 
    // returns 433

    你甚至可以使用Math.max来检测浏览器支持哪个属性:

    1 var
     
    scrollTop= Math.max(  
    2  
    doc.documentElement.scrollTop,  
    3  
    doc.body.scrollTop  
    4 );

    如果你想给一个元素增加class样式,可能原始的写法是这样的:

    1 function
     
    addclass(elm,newclass){  
    2   
    var
     
    c = elm.className;  
    3   
    elm.className = (c === 

    ) ? newclass : c+

    +newclass;

    而更优雅的写法是:

    1 function
     
    addclass(elm,newclass){  
    2   
    var
     
    classes = elm.className.split(

    );  
    3   
    classes.push(newclass);  
    4   
    elm.className = classes.join(

    );  
    5 }

       

    (4)事件委托

    事件是JavaScript非常重要的一部分。我们想给一个列表中的链接绑定点击事件,一般的做法是写一个循环,给每个链接对象绑定事件,HTML代码如下:

    1

    Great Web resources

      
    2
  • JavaScript数据类型:浏览器和nodejs之间是否有区别?JavaScript数据类型:浏览器和nodejs之间是否有区别?May 14, 2025 am 12:15 AM

    JavaScript核心数据类型在浏览器和Node.js中一致,但处理方式和额外类型有所不同。1)全局对象在浏览器中为window,在Node.js中为global。2)Node.js独有Buffer对象,用于处理二进制数据。3)性能和时间处理在两者间也有差异,需根据环境调整代码。

    JavaScript评论:使用//和 / * * / * / * /JavaScript评论:使用//和 / * * / * / * /May 13, 2025 pm 03:49 PM

    JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

    Python vs. JavaScript:开发人员的比较分析Python vs. JavaScript:开发人员的比较分析May 09, 2025 am 12:22 AM

    Python和JavaScript的主要区别在于类型系统和应用场景。1.Python使用动态类型,适合科学计算和数据分析。2.JavaScript采用弱类型,广泛用于前端和全栈开发。两者在异步编程和性能优化上各有优势,选择时应根据项目需求决定。

    Python vs. JavaScript:选择合适的工具Python vs. JavaScript:选择合适的工具May 08, 2025 am 12:10 AM

    选择Python还是JavaScript取决于项目类型:1)数据科学和自动化任务选择Python;2)前端和全栈开发选择JavaScript。Python因其在数据处理和自动化方面的强大库而备受青睐,而JavaScript则因其在网页交互和全栈开发中的优势而不可或缺。

    Python和JavaScript:了解每个的优势Python和JavaScript:了解每个的优势May 06, 2025 am 12:15 AM

    Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

    JavaScript的核心:它是在C还是C上构建的?JavaScript的核心:它是在C还是C上构建的?May 05, 2025 am 12:07 AM

    javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

    JavaScript应用程序:从前端到后端JavaScript应用程序:从前端到后端May 04, 2025 am 12:12 AM

    JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

    Python vs. JavaScript:您应该学到哪种语言?Python vs. JavaScript:您应该学到哪种语言?May 03, 2025 am 12:10 AM

    选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

    See all articles

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    Video Face Swap

    Video Face Swap

    使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

    热门文章

    热工具

    适用于 Eclipse 的 SAP NetWeaver 服务器适配器

    适用于 Eclipse 的 SAP NetWeaver 服务器适配器

    将Eclipse与SAP NetWeaver应用服务器集成。

    SublimeText3 英文版

    SublimeText3 英文版

    推荐:为Win版本,支持代码提示!

    SecLists

    SecLists

    SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

    SublimeText3 Mac版

    SublimeText3 Mac版

    神级代码编辑软件(SublimeText3)

    安全考试浏览器

    安全考试浏览器

    Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。