中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

JavaScript 基礎(chǔ)函數(shù)_深入剖析變量和作用域
來(lái)源:易賢網(wǎng) 閱讀:1008 次 日期:2016-06-27 14:11:54
溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript 基礎(chǔ)函數(shù)_深入剖析變量和作用域”,方便廣大網(wǎng)友查閱!

下面小編就為大家?guī)?lái)一篇JavaScript 基礎(chǔ)函數(shù)_深入剖析變量和作用域。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。

函數(shù)定義和調(diào)用

定義函數(shù),在JavaScript中,定義函數(shù)的方式如下:

function abs(x){

if(x >=0){

return x;

}else{

return -x;

}

}

上述abs() 函數(shù)的定義如下:

function 指出這是一個(gè)函數(shù)定義;

abs 是函數(shù)的名稱;

(x) 括號(hào)內(nèi)列出函數(shù)的參數(shù),多個(gè)參數(shù)以,分隔;

{...}之間的代碼是函數(shù)體,可以包含若干語(yǔ)句,甚至可以沒(méi)有任何語(yǔ)句。

注意:函數(shù)體內(nèi)部的語(yǔ)句在執(zhí)行時(shí),一旦執(zhí)行到return 時(shí),函數(shù)就執(zhí)行完畢,并將結(jié)果返回。因此內(nèi)部通過(guò)條件判斷和循環(huán)可以在實(shí)現(xiàn)非常復(fù)雜的。

如果沒(méi)有return語(yǔ)句,函數(shù)執(zhí)行完畢后也會(huì)返回結(jié)果,只是結(jié)果為undefined。

由于JavaScript的函數(shù)也是一個(gè)對(duì)象,上述定義的abs()函數(shù)實(shí)際上是一個(gè)函數(shù)對(duì)象,而函數(shù)名abs可以視為指向該函數(shù)的變量。

var abs = function(x){

if(x >= 0){

return x;

} else {

return -x;

}

}

在這種方式下,function (x) { ... }是一個(gè)匿名函數(shù),它沒(méi)有函數(shù)名。但是,這個(gè)匿名函數(shù)賦值給了變量abs,所以,通過(guò)變量abs就可以調(diào)用該函數(shù)。

兩種定義完全等價(jià),注意第二種方式按照完整語(yǔ)法需要在函數(shù)體末尾加一個(gè);,表示賦值語(yǔ)句結(jié)束。

調(diào)用函數(shù)時(shí),按順序傳入?yún)?shù)即可:

abs(10); // 返回10

abs(-9); // 返回9

由于JavaScript 允許傳入任意個(gè)參數(shù)而不受影響調(diào)用,因此傳入的參數(shù)比定義的參數(shù)多也沒(méi)有問(wèn)題,雖然函數(shù)內(nèi)部并不需要這些參數(shù)。

abs(10,'blablabla'); //返回10

abs(-9,'haha','hehe',null) // 返回9

傳入的參數(shù)比定義的少也沒(méi)有問(wèn)題

abs(); 返回NaN

此時(shí)abs(x)函數(shù)的參數(shù)x 將收到undefined,計(jì)算結(jié)果為NaN

function abs(x){

if(typeof x !=='number'){

throw 'Not a number':

}

if(x >=0){

return x;

}else{

return -x;

}

}

arguments

JavaScript 還有一個(gè)免費(fèi)贈(zèng)送的關(guān)鍵字 arguments,它只在函數(shù)內(nèi)部起作用,并且永遠(yuǎn)指向當(dāng)前函數(shù)的調(diào)用者傳入的所有參數(shù)。

function foo(x){

alert(x); // 10

for(var i=0; i < arguments.length;++){

alert(arguments[i]); // 10,20,30

}

}

foo(10.20,30)

利用arguments,你可以獲得調(diào)用者傳入的所有參數(shù)。也就是說(shuō),即使函數(shù)不定義任何參數(shù),還是可以拿到參數(shù)的值:

function abs(){

if(arguments.length ===0){

return 0;

}

var x = arguments[0]

return x >=0 ? x : -x;

}

abs(); //0

abs(10); // 10

abs(-9) //9

實(shí)際上arguments最常用于判斷傳入?yún)?shù)的個(gè)數(shù)。你可能會(huì)看到這樣的寫(xiě)法:

// foo(a[,b],c)

//接受2~3 個(gè)參數(shù),b 是可選參數(shù),如果只要出入兩個(gè)參數(shù),b默認(rèn)為null

function foo(a,b,c){

if(arguments.length ===2){

// 實(shí)際拿到的參數(shù)是a 和b c 為undefined

c = b;

b = null; // b 變?yōu)槟J(rèn)值

要把中間的參數(shù)b變?yōu)椤翱蛇x”參數(shù),就只能通過(guò)arguments判斷,然后重新調(diào)整參數(shù)并賦值。

rest 參數(shù)

由于JavaScript 函數(shù)允許接收任意個(gè)參數(shù),遇事我們就不得不用arguments 來(lái)獲取所有的參數(shù):

function foo(a,b){

var i, rest = [];

if(arguments.length > 2){

for(i = 2; i < arguments.length; i++){

rest.push(arguments[i]);

}

}

console.log('a =' + a);

console.log('b = ' + b);

console.log(rest);

}

為了獲取除了已定義參數(shù)a、b之外的參數(shù),我們不得不用arguments,并且循環(huán)要從索引2開(kāi)始以便排除前兩個(gè)參數(shù),這種寫(xiě)法很別扭,只是為了獲得額外的rest參數(shù),有沒(méi) 有更好的方法?

ES6標(biāo)準(zhǔn)引入了rest參數(shù),上面的函數(shù)可以改寫(xiě)為:

function foo(a,b,...rest){

console.log('a = ' + a);

console.log('b = ' + b);

console.log(rest);

}

foo(1,2,3,4,5);

//結(jié)果

// a = 1

// b = 2

// Array[3,4,5]

foo(1)

// 結(jié)果

// a = 1

// b = undefined

// Array []

rest 參數(shù)只能寫(xiě)在最后,前面用... 標(biāo)示,從運(yùn)行結(jié)果可知,傳入的參數(shù)先綁定 a , b, 多余的參數(shù)以數(shù)組形式交給變量 rest,所以,

不在需要 arguments 我們就獲取了全部參數(shù)。

如果傳入的參數(shù)連正常定義的參數(shù)都沒(méi)填滿,也不要緊,rest參數(shù)會(huì)接收一個(gè)空數(shù)組(注意不是undefined)。

return 語(yǔ)句

前面我們講到了JavaScript引擎有一個(gè)在行末自動(dòng)添加分號(hào)的機(jī)制,這可能讓你栽到return語(yǔ)句的一個(gè)大坑:、

function foo(){

return {name:'foo'};

}

foo(); // {name:'foo'}

要注意:

function foo(){

return: //自動(dòng)添加了分號(hào),相當(dāng)于return undefined

{name:'foo'}; // 這行語(yǔ)句已經(jīng)沒(méi)法執(zhí)行到了。

}

所以正確的多行寫(xiě)法是

function foo(){

return { // 這里不會(huì)自動(dòng)加分號(hào),因?yàn)楸硎菊Z(yǔ)句尚未結(jié)束。

name:'foo'

}

}

變量作用域

在JavaScript 中,用var 聲明的實(shí)際上是有作用域的。

如果一個(gè)變量在函數(shù)體內(nèi)部申明,則該變量的作用域?yàn)檎麄€(gè)函數(shù)體,在函數(shù)體外不該引用該變量。

‘use strict':

function foo(){

var x = 1;

x = x +1;

}

x = x +2; // RefrenceError 無(wú)法在函數(shù)體外引用該該變量x

如果兩個(gè)不同的函數(shù)各自申明了同一個(gè)變量,那么該變量只在各自的函數(shù)體內(nèi)起作用。換句話說(shuō),不同函數(shù)內(nèi)部的同名變量互相獨(dú)立,互不影響:

'use struct':

function foo(){

var x = 1;

x = x +1;

}

function bar (){

var x= 'A';

x = x + 'B';

}

由于JavaScript的函數(shù)可以嵌套,此時(shí),內(nèi)部函數(shù)可以訪問(wèn)外部函數(shù)定義的變量,反過(guò)來(lái)則不行:

'use strict';

function foo(){

var x =1;

function bar(){

var x = 1;

function bar(){

var y= x +1; //bar 可以訪問(wèn)foo 的變量x

}

var z = y + 1; //RefernceError! foo 不可以訪問(wèn)bar 的變量y!

}

}

如果內(nèi)部函數(shù)和外部函數(shù)的變量名重名怎么辦?

'use strict':

function foo(){

var x = 1;

function bar (){

var x = 'A';

alert('x in bar() =' + x); // 'A'

}

alert('x in foo()=' +x) //1

bar();

}

變量提升

JavaScript的函數(shù)定義有個(gè)特點(diǎn),它會(huì)先掃描整個(gè)函數(shù)體的語(yǔ)句,把所有申明的變量“提升”到函數(shù)頂部:

'use strict';

function foo(){

var x='Hello,'+y;

alert(x);

var y = 'Bob';

}

foo();

對(duì)于上述foo()函數(shù),JavaScript引擎看到的代碼相當(dāng)于:

function foo(){

var y; // 提升變量y的

var x = 'Hello' + y;

alert(x);

y = 'Bob';

}

由于JavaScript的這一怪異的“特性”,我們?cè)诤瘮?shù)內(nèi)部定義變量時(shí),請(qǐng)嚴(yán)格遵守“在函數(shù)內(nèi)部首先申明所有變量”這一規(guī)則。最常見(jiàn)的做法是用一個(gè)var申明函數(shù)內(nèi)部用到的所有變量:

function foo(){

var x =1, // x 初始化為1

y = x +1, // y 初始化為2

z,i; // z和i 為undefined

// 其他語(yǔ)句

for(i =0; i<100; i++){

...

}

}

全局作用域

不在任何函數(shù)內(nèi)定義的變量就具有全局作用域,實(shí)際上,JavaScript 默認(rèn)有一個(gè)全局作用域的變量實(shí)際上唄綁定到window 的一個(gè)屬性。

‘use strict';

var sourse = 'Learn JavaScript';

alert(course); // 'Learn JavaScript';

alert(window.course); // 'Learn JavaScript'

名字空間

全局變量會(huì)綁定到window 上,不同的JavaScript 文件如果使用相同的全局變量,或者定義了相同名字的頂層函數(shù),都會(huì)造成

命名沖突,并且很難被發(fā)現(xiàn),

減少?zèng)_突的一個(gè)方法是把自己的所有的變量和函數(shù)全部綁定到一個(gè)全局變量中。

// 唯一的曲劇變量MYAPP

var MYAPP = {};

//其他變量:

MYAPP.name = 'myapp';

MYAPP.version = 1.0;

// 其他函數(shù)

MYAPP.foo = function (){

return 'foo';

};

把自己的代碼全部放入唯一的名字空間MYAPP中,會(huì)大大減少全局變量沖突的可能。

局部作用域

由于JavaScript 的變量作用域?qū)嶋H上是函數(shù)內(nèi)部,我們?cè)趂or 循環(huán)等語(yǔ)句塊中是無(wú)法定義具有無(wú)法定義具有局部作用域的變量的。

function foo(){

for(var i = 0; i<100; i++){

//

}

i+=100; // 仍然可以引用變量;

}

為了解決塊級(jí)作用域,ES6引入了新的關(guān)鍵字let,用let替代var可以申明一個(gè)塊級(jí)作用域的變量:

function foo(){

var sum = 0;

for(let i=0; i<100;i++){

sum +=i;

}

i +=1;

}

常量

由于var 和let 聲明的變量,如果要聲明一個(gè)常量,在ES6 之前是不行的,我們通常用全部大寫(xiě)的變量倆表示這是一個(gè)常量

不要修改他的值。

var PI = 3.14;

ES6標(biāo)準(zhǔn)引入了新的關(guān)鍵字const 來(lái)定義常量,const 與 let都具有塊級(jí)作用域;

const PI = 3.14;

PI = 3; // 某些瀏覽器不報(bào)錯(cuò),但是無(wú)效果。

PI; // 3.14

以上這篇JavaScript 基礎(chǔ)函數(shù)_深入剖析變量和作用域就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:JavaScript 基礎(chǔ)函數(shù)_深入剖析變量和作用域
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!

2026上岸·考公考編培訓(xùn)報(bào)班

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
久久都是精品| 国产欧美精品| 亚洲视频在线一区观看| 欧美一区二区三区日韩| 国产精品久久久久久久电影 | 国内精品久久久久久影视8| 午夜伦欧美伦电影理论片| **性色生活片久久毛片| 国产精品视频专区| 狠狠色综合网站久久久久久久| 久久久久久久精| 亚洲欧美成人网| 欧美在线视频二区| 伊大人香蕉综合8在线视| 欧美日韩在线视频观看| 亚洲尤物在线| 亚洲一区二区三区精品在线| 激情欧美日韩| 伊人久久婷婷色综合98网| 亚洲午夜未删减在线观看| 国产精品二区三区四区| 欧美激情精品久久久久久| 欧美在现视频| 亚洲一区二区网站| 亚洲九九精品| 亚洲国产一二三| 一区免费视频| 国产一本一道久久香蕉| 在线观看av不卡| 国产免费一区二区三区香蕉精| 国产精一区二区三区| 精久久久久久久久久久| 欧美激情一区二区三区全黄 | 国产一区二区欧美日韩| 欧美国产91| 亚洲国产日韩欧美| 国产一区二区无遮挡| 国产精品女人久久久久久| 日韩一级黄色片| 国产精品夜夜夜一区二区三区尤| 亚洲一区制服诱惑| 国内精品久久久久久| 国产视频在线一区二区| 久久精品夜色噜噜亚洲aⅴ| 国产视频久久久久| 欧美日韩国产91| 狠狠久久亚洲欧美| 午夜精品免费在线| 国产精品久久久对白| 国产精品入口日韩视频大尺度| 亚洲欧美日韩另类精品一区二区三区| 国产欧美一区二区三区在线老狼| 亚洲一区在线直播| 亚洲欧美另类中文字幕| 亚洲欧美在线x视频| 久久男人资源视频| 狼人社综合社区| 久久综合久色欧美综合狠狠 | 免费成人性网站| 国产精品区一区二区三区| 国产婷婷成人久久av免费高清 | 鲁大师影院一区二区三区| 一本久久综合| 久久久999| 国产欧美亚洲日本| 亚洲国产成人91精品| 91久久精品久久国产性色也91| 亚洲区第一页| 欧美在线首页| 欧美激情一区三区| 国产精品欧美激情| 亚洲精品日产精品乱码不卡| 亚洲一区二区三区激情| 欧美一区二区三区在线视频| 欧美日韩视频| 黄色资源网久久资源365| 亚洲毛片在线| 欧美成人一区二区三区在线观看 | 日韩系列在线| 久久一区二区三区四区| 欧美体内谢she精2性欧美| 国产在线麻豆精品观看| 在线一区二区三区四区五区| 久久综合给合久久狠狠色 | 国产免费观看久久| 久久国产精品电影| 在线视频日韩| 欧美日韩国产成人| 在线观看国产成人av片| 韩国成人福利片在线播放| 亚洲午夜在线观看| 国产亚洲一级| 欧美专区亚洲专区| 久久精品国产77777蜜臀| 欧美成人免费在线视频| 欧美日韩精品免费观看| 欧美日韩在线亚洲一区蜜芽| 欧美日韩国产在线看| 欧美激情一区在线| 欧美暴力喷水在线| 欧美xxx成人| 免费观看成人网| 欧美日韩一区二区在线播放| 亚洲综合精品| 久久精品日产第一区二区| 久久高清国产| 欧美日韩精品免费观看视频| 国产精品免费福利| 亚洲高清精品中出| 亚洲网站在线观看| 麻豆国产精品va在线观看不卡| 老鸭窝91久久精品色噜噜导演| 亚洲韩国精品一区| 亚洲狼人精品一区二区三区| 午夜精品久久久久久99热| 免费不卡在线观看av| 国产精品多人| 亚洲精品影视| 久久一区二区三区四区| 欧美日韩在线播放一区二区| 黑人中文字幕一区二区三区 | 宅男在线国产精品| 快播亚洲色图| 欧美午夜不卡视频| 亚洲精品国产精品久久清纯直播 | 亚洲美女黄色片| 亚洲永久免费观看| 欧美视频观看一区| 亚洲免费精彩视频| 欧美三区在线| 亚洲小视频在线观看| 免费欧美日韩| 国内精品嫩模av私拍在线观看| 在线一区免费观看| 欧美日韩国产精品成人| 欧美日韩亚洲三区| 91久久精品一区| 欧美mv日韩mv国产网站| 99视频在线精品国自产拍免费观看| 久久全国免费视频| 亚洲黄色在线| 国产精品久久久久7777婷婷| 欧美亚洲综合另类| 欧美日韩在线观看一区二区| 午夜精品久久久久久99热软件| 欧美久久久久久蜜桃| 亚洲美女免费精品视频在线观看| 欧美高清视频一区二区三区在线观看| 亚洲国产综合在线看不卡| 99av国产精品欲麻豆| 久久久久久9999| 国产精品一区二区三区四区| 91久久久久久| 欧美 日韩 国产一区二区在线视频| 国产最新精品精品你懂的| 在线观看亚洲一区| 六月婷婷一区| 夜夜嗨av一区二区三区中文字幕 | 久久婷婷国产综合精品青草| av成人天堂| 亚洲一区二区三区四区五区午夜| 亚洲第一精品夜夜躁人人爽| 韩国一区电影| 亚洲人成绝费网站色www| 亚洲精选视频在线| 亚洲在线第一页| 欧美亚洲日本一区| 久久精品亚洲一区二区三区浴池| 久久精品最新地址| 蜜臀va亚洲va欧美va天堂| 欧美久久电影| 国产精品一区二区久久| 国产真实精品久久二三区| 亚洲国产专区| 午夜综合激情| 欧美日韩国产美女| 国内精品久久久久影院色| 亚洲狼人综合| 欧美日韩视频一区二区| 国产一区二区三区四区老人| 亚洲精品乱码| 久久男女视频| 国产在线观看精品一区二区三区 | 一区二区欧美精品| 久久野战av| 国产亚洲一区二区在线观看| 亚洲毛片在线看| 欧美 日韩 国产一区二区在线视频 | 久久久久9999亚洲精品| 免费欧美电影| 在线成人h网| 久久夜色撩人精品| 午夜精品视频在线| 国产欧美日本| 欧美在线播放一区| 国产日韩欧美综合精品| 性欧美video另类hd性玩具| 国产精品久久影院| 亚洲一级二级| 国产精品嫩草99av在线|