JavaScript中的細(xì)節(jié)分析
更新時(shí)間:2012年06月30日 00:49:31 作者:
高山登不上,不是因?yàn)轶w力不支,只因鞋里一粒。學(xué)習(xí)也是如此,因而有必要把JavaScript中常見的和與其它語言不同的那些細(xì)節(jié)學(xué)習(xí)一下
JavaScript區(qū)分大小寫:在JavaScript中變量、函數(shù)都是區(qū)分大小寫的,例如:
function myfunction(){}和
function myFunction(){}不同
JavaScript中核心對(duì)象Array、Object等也是區(qū)分大小寫。
單引號(hào)和雙引號(hào):這個(gè)問題在學(xué)SQLServer拼接字符串"select * from page where name='lida'"時(shí)就有疑惑:后面都的三個(gè)'到底是雙引號(hào)在前還是單引號(hào)在前?學(xué)的多了知道,雙引號(hào)是編程語言使用的,單引號(hào)是SQLserver標(biāo)明字符串類型的。但是在JavaScript中單引號(hào)和雙引號(hào)沒有特殊的區(qū)別,都可以用來創(chuàng)建字符串,但是一般情況下JavaScript使用單引號(hào),HTML等屬性值必須使用雙引號(hào);同時(shí)單引號(hào)可以包括雙引號(hào),雙引號(hào)也可以包括單引號(hào) ;特殊情況下需要使用轉(zhuǎn)義符號(hào)"\",例如:
var temp='<p class="nameA">What\'s this?';
括號(hào)的作用:和其他語言一樣,JavaScript中的括號(hào)同樣是兩種作用,一種是當(dāng)作分隔符使用,例如:(1+1)*2;第二種作用是表達(dá)式,例如:(1+1)*2;第二種作用是表達(dá)式,例如:(function (){})()中被分開的括號(hào)為分隔符,后面的括號(hào)表示執(zhí)行方法。
函數(shù)的調(diào)用和引用:
var temp=myFunction();
var temp=myFunction;
因?yàn)槔ㄌ?hào)可以代表執(zhí)行,第一個(gè)temp代表的是myFunction函數(shù)的返回值,而第二個(gè)temp代表的是把myFunction賦值給temp。例如:
<script type="text/javascript">
// JavaScript Document
(function () {
function $() {
alert("正在Buffering!");
}
window['LD'] = {}
window['LD']['$'] = $;
}
)();
window.onload = LD.$;
</script>
網(wǎng)頁可以正常加載,因?yàn)檫@代表把$方法賦值給了window.onload,頁面加載運(yùn)行的是自己編寫的$()函數(shù);如果把這句換成
window.onload=LD.$();運(yùn)行結(jié)果如下;首先會(huì)顯示“正在Buffering”,然后是

這是因?yàn)閛nload事件不需要返回值,而$函數(shù)也沒有返回值,所以會(huì)導(dǎo)致尚未實(shí)現(xiàn)的錯(cuò)誤。
換行:無論是用哪種引號(hào)創(chuàng)建字符串,中間都不能包含強(qiáng)制換行符。如下:
var temp='<h2 class="nameA">List</h2>
<ol>
</ol>'
將導(dǎo)致解析錯(cuò)誤,可以使用\或+來換行:
var temp='<h2 class="nameA">List</h2>\
<ol>\
</ol>\
';
大括號(hào)和分號(hào)可選:
在JavaScript中分號(hào)和大括號(hào)不是必須的,例如alert('A');和alert('A')沒有區(qū)別,但是在if語句處運(yùn)行有差異,最好不要省略。
重載
JavaScript是基于原型的面向?qū)ο?,沒有如C#中的重載,在此我們可以稱之為替換,同名函數(shù)無論參數(shù)個(gè)數(shù)是否相同,程序都會(huì)執(zhí)行最后一個(gè)同名函數(shù),例如function alert(){}將會(huì)覆蓋JavaScript中的alert函數(shù)。
作用域和閉包
可以參加我的博客《JavaScript中的作用域鏈和閉包》。
復(fù)制代碼 代碼如下:
function myfunction(){}和
function myFunction(){}不同
JavaScript中核心對(duì)象Array、Object等也是區(qū)分大小寫。
單引號(hào)和雙引號(hào):這個(gè)問題在學(xué)SQLServer拼接字符串"select * from page where name='lida'"時(shí)就有疑惑:后面都的三個(gè)'到底是雙引號(hào)在前還是單引號(hào)在前?學(xué)的多了知道,雙引號(hào)是編程語言使用的,單引號(hào)是SQLserver標(biāo)明字符串類型的。但是在JavaScript中單引號(hào)和雙引號(hào)沒有特殊的區(qū)別,都可以用來創(chuàng)建字符串,但是一般情況下JavaScript使用單引號(hào),HTML等屬性值必須使用雙引號(hào);同時(shí)單引號(hào)可以包括雙引號(hào),雙引號(hào)也可以包括單引號(hào) ;特殊情況下需要使用轉(zhuǎn)義符號(hào)"\",例如:
復(fù)制代碼 代碼如下:
var temp='<p class="nameA">What\'s this?';
括號(hào)的作用:和其他語言一樣,JavaScript中的括號(hào)同樣是兩種作用,一種是當(dāng)作分隔符使用,例如:(1+1)*2;第二種作用是表達(dá)式,例如:(1+1)*2;第二種作用是表達(dá)式,例如:(function (){})()中被分開的括號(hào)為分隔符,后面的括號(hào)表示執(zhí)行方法。
函數(shù)的調(diào)用和引用:
復(fù)制代碼 代碼如下:
var temp=myFunction();
var temp=myFunction;
因?yàn)槔ㄌ?hào)可以代表執(zhí)行,第一個(gè)temp代表的是myFunction函數(shù)的返回值,而第二個(gè)temp代表的是把myFunction賦值給temp。例如:
復(fù)制代碼 代碼如下:
<script type="text/javascript">
// JavaScript Document
(function () {
function $() {
alert("正在Buffering!");
}
window['LD'] = {}
window['LD']['$'] = $;
}
)();
window.onload = LD.$;
</script>
網(wǎng)頁可以正常加載,因?yàn)檫@代表把$方法賦值給了window.onload,頁面加載運(yùn)行的是自己編寫的$()函數(shù);如果把這句換成
window.onload=LD.$();運(yùn)行結(jié)果如下;首先會(huì)顯示“正在Buffering”,然后是

這是因?yàn)閛nload事件不需要返回值,而$函數(shù)也沒有返回值,所以會(huì)導(dǎo)致尚未實(shí)現(xiàn)的錯(cuò)誤。
換行:無論是用哪種引號(hào)創(chuàng)建字符串,中間都不能包含強(qiáng)制換行符。如下:
復(fù)制代碼 代碼如下:
var temp='<h2 class="nameA">List</h2>
<ol>
</ol>'
將導(dǎo)致解析錯(cuò)誤,可以使用\或+來換行:
復(fù)制代碼 代碼如下:
var temp='<h2 class="nameA">List</h2>\
<ol>\
</ol>\
';
大括號(hào)和分號(hào)可選:
在JavaScript中分號(hào)和大括號(hào)不是必須的,例如alert('A');和alert('A')沒有區(qū)別,但是在if語句處運(yùn)行有差異,最好不要省略。
重載
JavaScript是基于原型的面向?qū)ο?,沒有如C#中的重載,在此我們可以稱之為替換,同名函數(shù)無論參數(shù)個(gè)數(shù)是否相同,程序都會(huì)執(zhí)行最后一個(gè)同名函數(shù),例如function alert(){}將會(huì)覆蓋JavaScript中的alert函數(shù)。
作用域和閉包
可以參加我的博客《JavaScript中的作用域鏈和閉包》。
相關(guān)文章
javaScript合并對(duì)象的多種方式及知識(shí)擴(kuò)展
眾所周知JavaScript中有多種方法可以合并對(duì)象,下面這篇文章主要給大家介紹了關(guān)于javaScript合并對(duì)象的多種方式及知識(shí)擴(kuò)展,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02JavaScript作用域與作用域鏈?zhǔn)褂弥攸c(diǎn)講解
當(dāng)代碼在一個(gè)環(huán)境中執(zhí)行時(shí),會(huì)創(chuàng)建變量對(duì)象的一個(gè)作用域鏈,作用域鏈的用途是保證對(duì)執(zhí)行環(huán)境有權(quán)訪問的所有變量和函數(shù)的有序訪問,下面這篇文章主要給大家介紹了關(guān)于JavaScript作用域與作用域鏈的相關(guān)資料,需要的朋友可以參考下2022-10-10js冒泡法和數(shù)組轉(zhuǎn)換成字符串示例代碼
將數(shù)組轉(zhuǎn)換成字符串的方法有很多,想必大家也不會(huì)陌生,下面為大家講解下js冒泡法的使用,感興趣的朋友可以參考下2013-08-08ionic js 模型 $ionicModal 可以遮住用戶主界面的內(nèi)容框
這篇文章主要介紹了ionic js 模型 $ionicModal 可以遮住用戶主界面的內(nèi)容框的相關(guān)資料,需要的朋友可以參考下2016-06-06javascript學(xué)習(xí)總結(jié)之js使用技巧
本篇文章給大家分享javascript學(xué)習(xí)總結(jié)之js使用技巧,都是精華喔~小伙伴快來學(xué)習(xí)吧。2015-09-09JavaScript中new操作符的原理與實(shí)現(xiàn)詳解
你知道new嗎?你知道new的實(shí)現(xiàn)原理嗎?你能手寫new方法嗎?不要擔(dān)心,這篇文件就來帶大家深入了解一下JavaScript中的new操作符,感興趣的小伙伴可以學(xué)習(xí)一下2022-10-10教你如何使用firebug調(diào)試功能了解javascript閉包和this
這篇文章主要介紹了教你如何使用firebug調(diào)試功能了解javascript閉包和this,javascript的調(diào)試也是一個(gè)比較大的難點(diǎn),很多基礎(chǔ)的東西都需要自己去摸索,這里將自己的經(jīng)驗(yàn)分享給大家,希望對(duì)大家能夠有所幫助2015-03-03關(guān)于onchange事件在IE和FF下的表現(xiàn)及解決方法
本篇文章主要是對(duì)關(guān)于onchange事件在IE和FF下的表現(xiàn)及解決方法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-03-03