javascript中大括號(hào)怎么使用

這篇文章主要介紹“javascript中大括號(hào)怎么使用”,在日常操作中,相信很多人在javascript中大括號(hào)怎么使用問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”javascript中大括號(hào)怎么使用”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

專注于為中小企業(yè)提供成都做網(wǎng)站、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)鳩江免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了近1000家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

JavaScript中大括號(hào)的用法:1、用于組織復(fù)合語句;2、用于定義一個(gè)對(duì)象,大部分情況下要有成對(duì)的屬性和值;3、用于聲明函數(shù)或函數(shù)直接量;4、用作結(jié)構(gòu)化異常處理的語法符號(hào)。

本教程操作環(huán)境:windows10系統(tǒng)、javascript1.8.5版、Dell G3電腦。

javascript中大括號(hào)的用法是什么

Javascript中大括號(hào)"{}"有四種語義作用:

語義1. 組織復(fù)合語句,這是最常見的:

if( condition ) {
  //...
}else {
  //...
}
for() {
  //...
}

語義2,對(duì)象直接量聲明:

var obj = {
    name : 'jack',
    age : 23
};

整個(gè)是個(gè)賦值語句,其中的{name:'jack',age:23}是個(gè)表達(dá)式。

語義3,聲明函數(shù)或函數(shù)直接量:

function f1(){
    //...
}
var f2 = function(){
    //...
}

f1與非f2的區(qū)別是前者在語法解釋期,后者在運(yùn)行期。區(qū)別在于:如果調(diào)用該函數(shù)的代碼在函數(shù)定義之后,則沒有區(qū)別;如果調(diào)用該函數(shù)的代碼在函數(shù)定義之前,則f1仍然可以調(diào)用,f2則會(huì)報(bào)錯(cuò),提示f2未定義。

語義4,結(jié)構(gòu)化異常處理的語法符號(hào):

try {
    //...
}catch( ex ){
    //...
}finally{
    //...
}

這里的大括號(hào)與符合語句(語義1 )是有區(qū)別的,大括號(hào)中如果只有一條語句,在if/else/for等中大括號(hào)是可以省略的,但try/catch/finally則不能省略。

以下代碼糾結(jié)了偶N久:

function(){}() //匿名函數(shù)立即執(zhí)行, 語法分析期報(bào)
{}.constructor //獲取對(duì)象直接量的構(gòu)造器,語法分析期報(bào)錯(cuò)

令人不解的是為何[].constructor這么寫卻不報(bào)錯(cuò)呢,一個(gè)是想獲取對(duì)象直接量的構(gòu)造器,一個(gè)是獲取數(shù)組直接量的構(gòu)造器而已。

當(dāng)然添加個(gè)變量接收也不會(huì)報(bào)錯(cuò),var c = {}.constructor;

同樣的情況如:var fn = function(){}(),也不會(huì)報(bào)錯(cuò)。

實(shí)際上是js的"語句優(yōu)先"在作怪,即{}被理解成復(fù)合語句塊(語義1 )而不是對(duì)象直接量(語義2 )或聲明函數(shù)(語義3 )的語義。

function(){}(),大括號(hào)被理解成復(fù)合語句,自然前面的function()聲明函數(shù)的語法不完整導(dǎo)致語法分析期出錯(cuò)。{}.constructor,大括號(hào)被理解成復(fù)合語句,大括號(hào)后面是點(diǎn)運(yùn)算符,點(diǎn)運(yùn)算符前沒有合理的對(duì)象自然也報(bào)錯(cuò)。

修復(fù)方式眾所周知:加個(gè)強(qiáng)制運(yùn)算符()

(function(){})(),(function(){});//強(qiáng)制其理解為函數(shù)(語義3 ),"函數(shù)()"表示執(zhí)行該函數(shù),即聲明后立即執(zhí)行了。({}).constructor //({})強(qiáng)制把大括號(hào)理解成對(duì)象直接量(語義2 ),"對(duì)象.xx"表示獲取對(duì)象的成員,自然后面的點(diǎn)運(yùn)算符可以正常執(zhí)行了。

function(){}(); 語法錯(cuò)誤的原因和 ();函數(shù)調(diào)用運(yùn)算符無關(guān)。

本質(zhì)原因是, function(){} ,根據(jù)詞法分析期對(duì)token的有效分組。function被看成這個(gè)ExpressionStatement 的start 位置的第一個(gè)token元素。這是EMCA262所不允許的。不允許的原因很明確,就是怕引起函數(shù)表達(dá)式和函數(shù)聲明的歧義。你可以理解為 function 關(guān)鍵字永遠(yuǎn)不能在一個(gè)ExpressionStaement的首位。

來看看賦值語句f = function(){};

f : LeftHandSideExpression
= : AssignmentOperator

function(){};此時(shí)被看做是整個(gè)語句的賦值表達(dá)式部分即 AssignmentExpression。 所以他合理合法的通過了語法檢查,成為了一個(gè)函數(shù)表達(dá)式.FunctionExpression.

所以這時(shí)候,即使你 f = function(){}(); 在語法上也是合法的。

到此,關(guān)于“javascript中大括號(hào)怎么使用”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

名稱欄目:javascript中大括號(hào)怎么使用
轉(zhuǎn)載源于:http://bm7419.com/article18/pccidp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、App開發(fā)網(wǎng)站建設(shè)、網(wǎng)站策劃網(wǎng)站內(nèi)鏈、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名