成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Function

el09xccxy / 2013人閱讀

摘要:什么是函數(shù)函數(shù)封裝一項(xiàng)專門任務(wù)的步驟清單的代碼段,起一個(gè)名字。程序中提供的一項(xiàng)服務(wù)的步驟說(shuō)明何時(shí)使用函數(shù)當(dāng)一項(xiàng)任務(wù)需要反復(fù)執(zhí)行,但又不希望重復(fù)編寫時(shí)。何時(shí)如何為參數(shù)變量賦值在調(diào)用函數(shù)時(shí),按照參數(shù)定義時(shí)的順序和個(gè)數(shù),依次傳入?yún)?shù)值。

function
什么是函數(shù):
函數(shù):封裝一項(xiàng)專門任務(wù)的步驟清單的代碼段,起一個(gè)名字。(**程序中提供的一項(xiàng)服務(wù)的步驟說(shuō)明**)
 何時(shí)使用函數(shù)?當(dāng)一項(xiàng)任務(wù)需要反復(fù)執(zhí)行,但又不希望重復(fù)編寫時(shí)。(**代碼重用!**)
 如何聲明函數(shù):function 任務(wù)名([參數(shù)變量列表]){
            步驟清單代碼段
                        [return 返回值]
                  }
     ***函數(shù)名(任務(wù)名): 指向函數(shù)定義的一個(gè)變量
                      函數(shù):封裝函數(shù)定義的引用類型對(duì)象
            ***聲明時(shí),不執(zhí)行!也不讀取內(nèi)部的代碼!
        如何調(diào)用函數(shù)執(zhí)行:任何位置: 函數(shù)名([參數(shù)值列表]);
            ***調(diào)用時(shí),才讀取內(nèi)部的代碼,執(zhí)行
            
 參數(shù)變量:專門接收要傳入方法中處理的數(shù)據(jù)的變量。
  何時(shí)需要定義參數(shù):如果一個(gè)函數(shù),必須一些數(shù)據(jù)才可正常執(zhí)行,需要幾個(gè)數(shù)據(jù),就定義幾個(gè)參數(shù)變量。
  何時(shí)如何為參數(shù)變量賦值:在調(diào)用函數(shù)時(shí),按照參數(shù)定義時(shí)的順序和個(gè)數(shù),依次傳入?yún)?shù)值。
  
    返回值:函數(shù)的執(zhí)行結(jié)果
            何時(shí)需要返回值:只要函數(shù)需要有明確的執(zhí)行結(jié)果時(shí)
                         如果調(diào)用者需要獲得明確的執(zhí)行結(jié)果時(shí)
            如何定義返回值: 函數(shù)定義內(nèi)部,一般函數(shù)體結(jié)尾
                            return 值;
            調(diào)用者何時(shí)如何獲得返回值:
                    1. 一個(gè)有返回值的函數(shù)調(diào)用,可以當(dāng)做一個(gè)值使用
                    2. 調(diào)用時(shí),可使用變量保存住函數(shù)調(diào)用的返回值
function buy(what,moeny){
    console.log("Step1:取盒飯");
    console.log("Step2:去食堂");
    console.log("Step3:打飯"+what);
    moeny-=3;
    console.log("Step4:扣款3元,余額:"+moeny);
    console.log("Step5:回宿舍");
    return "香噴噴的"+what;
   }
   console.log(buy("宮保雞丁",10)); 
***變量作用域:一個(gè)變量的可用范圍
    有2種:1. 全局作用域:window
          全局變量——放在全局作用域(window)中的變量
          可在程序的任何位置訪問(wèn)全局變量
         2. 局部作用域:在函數(shù)調(diào)用時(shí)才創(chuàng)建的作用域
              局部變量:2種:1. 參數(shù)變量
                          2. 在函數(shù)定義中var的變量
              ***僅在函數(shù)調(diào)用時(shí),動(dòng)態(tài)創(chuàng)建
                 調(diào)用時(shí),如果局部有,就不用全局的!
              ***調(diào)用后,隨局部作用域一同銷毀
var kl=10;
   function rose(){
    var kl=5;
    kl--;
    console.log(kl);
   }
   function jack() {
    kl--;
    console.log(kl);
   }
   console.log(kl);//全局kl=10
   rose();//4
   console.log(kl);//全局kl=10
   jack();//9
   console.log(kl);//全局kl=9
聲明提前
  聲明提前:正式開始執(zhí)行程序前,先將var聲明的變量和function聲明的函數(shù),提前到*當(dāng)前作用域*頂部,集中聲明,賦值留在原地。
var n=100;
            function fun(){
                var n;//undifend
                console.log(n);
                n=99;
                console.log(n);
            }
            fun();//99
            console.log(n);

按值傳遞:兩變量間賦值,或?qū)⒆兞孔鳛楹瘮?shù)的參數(shù)傳遞時(shí)都僅將變量中的值,復(fù)制一個(gè)副本給對(duì)方!

var n=100;
            var m=n;
            n++;
            console.log(m);//100

全局函數(shù):ES標(biāo)準(zhǔn)中規(guī)定的,由瀏覽器廠商實(shí)現(xiàn)的,不需要任何對(duì)象前綴就可直接訪問(wèn)的函數(shù).

 比如:parseInt/Float(str),isNaN(n)

 比如:alert() prompt()——BOM
分支結(jié)構(gòu)

分支結(jié)構(gòu):

程序結(jié)構(gòu):3種:
 順序結(jié)構(gòu):默認(rèn)程序都是自上向下逐行順序執(zhí)行
 分支結(jié)構(gòu):根據(jù)不同的條件,選擇執(zhí)行不同的操作
         操作的復(fù)雜程度
 循環(huán)結(jié)構(gòu):讓程序反復(fù)執(zhí)行同一代碼段。

分支結(jié)構(gòu):3種情況:
1. 一個(gè)條件,一件事:滿足條件就執(zhí)行,(不滿足就什么都不做)
短路邏輯:條件&&(操作1,操作2...)
    何時(shí)使用:操作非常簡(jiǎn)單時(shí)
  if結(jié)構(gòu):如果 滿足*條件*, 就執(zhí)行代碼段
          if(條件){
     滿足條件時(shí),才能執(zhí)行的代碼段
          }
var price=parseFloat(prompt("請(qǐng)輸入單價(jià)"));
            var count=parseFloat(prompt("輸入數(shù)量"));
            var money=parseFloat(prompt("輸入收款金額"));
            var total=price*count;
            if(total>=500){
                total*=0.8;
            }
            var change=money-total;
            console.log("應(yīng)收:"+total+";找零"+change);
2. 一個(gè)條件,兩件事:二選一執(zhí)行!
         如果 滿足*條件*,就執(zhí)行操作1,否則,執(zhí)行操作2
      三目運(yùn)算:條件?操作1:操作2;
        何時(shí)使用:操作1和操作2,都非常簡(jiǎn)單時(shí)
         if...else結(jié)構(gòu):
         if(條件){
        滿足條件才執(zhí)行的代碼段
         }else{//否則
        不滿足條件才執(zhí)行的代碼段
         }
var price=parseFloat(prompt("請(qǐng)輸入單價(jià)"));
            var count=parseFloat(prompt("輸入數(shù)量"));
            var money=parseFloat(prompt("輸入收款金額"));
            var total=price*count;
            if(money>=total){
                var change=money-total;
              console.log("應(yīng)收:"+total+";找零"+change);
            }else{
                var change=total-moeny;
              console.log("應(yīng)收:"+total+";還差"+change);
            }

多個(gè)條件,多件事,多選一執(zhí)行!(有可能都不執(zhí)行)

  如果 滿足 條件1 就執(zhí)行 操作1

否則,如果滿足 條件2 就執(zhí)行 操作2
... ...

               [否則,默認(rèn)操作]

三目:條件1?操作1:

     條件2?操作2:
             ...:
         默認(rèn)操作——不可省略

if...else if結(jié)構(gòu):

    if(條件1){
 滿足條件1才執(zhí)行的操作1;
     }else if(條件2){
 滿足條件2才執(zhí)行的操作2;
     }else if(...){
 ...
     }[else{
  如果以上任何條件都不滿足,則執(zhí)行默認(rèn)操作
     }]

if (score<0||score>100) {
      console.log("無(wú)效分?jǐn)?shù)");
     } else if(score>=90){
      console.log("A");
     } else if (score>=80) {
      console.log("B");
     } else if (score>=70) {
      console.log("C");
     }  else {
      console.log("D");
     }

switch...case結(jié)構(gòu):
何時(shí)使用:當(dāng)條件都是全等比較時(shí),才可用switch結(jié)構(gòu)
switch(表達(dá)式){ //1. 計(jì)算表達(dá)式的結(jié)果

//用表達(dá)式的值和每個(gè)case后的值做**全等**比較
//碰到一個(gè)全等的case值,則進(jìn)入該case開始執(zhí)行

//并默認(rèn)以此觸發(fā)之后所有case的執(zhí)行
case 值1:

 滿足值1才執(zhí)行的代碼段1;
case 值2:
     滿足值2才執(zhí)行的代碼段2;
     ...:
     ... ...
 default:
 如果前邊的值都不滿足,執(zhí)行默認(rèn)代碼段

}

 switch(parseInt(prompt("請(qǐng)按鍵:"))){
      case 1:
      console.log("查詢進(jìn)行中.....");
      case 2:
      console.log("取款中......");
      case 3:
      console.log("轉(zhuǎn)賬進(jìn)行中....");
      case 0:
      console.log("歡迎下次再來(lái)!");
      default:
      console.lop("無(wú)效按鍵");
     }

break: 中止當(dāng)前結(jié)構(gòu)的執(zhí)行,并跳出結(jié)構(gòu)。

位置:在每個(gè)case之間

何時(shí)可以省略部分break:上下兩個(gè)case希望執(zhí)行相同代碼時(shí)

switch(parseInt(prompt("請(qǐng)按鍵:"))){
      case 1:
      console.log("查詢進(jìn)行中.....");
      break;
      case 2:
      case 3:
      console.log("系統(tǒng)維護(hù)中....");
      break;
      case 0:
      console.log("歡迎下次再來(lái)!");
      break;
      default:
      console.log("無(wú)效按鍵");
     }

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/81261.html

相關(guān)文章

  • underscore源碼解析

    說(shuō)明1、源碼結(jié)構(gòu)通覽,簡(jiǎn)單注釋說(shuō)明2、通過(guò)調(diào)用方法講解核心代碼邏輯 一、源碼的結(jié)構(gòu) 為了方便比對(duì)源碼,按源碼的結(jié)構(gòu)順序展示。underscore是個(gè)輕量級(jí)的工具庫(kù),大部分代碼是實(shí)現(xiàn)特定功能以函數(shù)的形式存在,本身會(huì)比較簡(jiǎn)單,沒對(duì)方法具體說(shuō)明,可直接參考underscore中文文檔 (function() { var root = this; var previousUnderscore = ...

    kid143 評(píng)論0 收藏0
  • 函數(shù)式JS: 原來(lái)promise是這樣的monad

    摘要:定義這是類型簽名的表述。實(shí)際上對(duì)應(yīng)著,只是在里作為立即量傳入,在和的返回值中作為閉包引用傳入。同時(shí)根據(jù)看出返回值是用回調(diào)返回值的。的輸出是的包裹。的方法借助了閉包引用額外輸入了,而輸入的函數(shù)輸入是輸出則是借助實(shí)現(xiàn)的。 轉(zhuǎn)載請(qǐng)注明出處: http://hai.li/2017/03/27/prom... 背景 上篇文章 函數(shù)式JS: 一種continuation monad推導(dǎo) 得到了一個(gè)...

    ZweiZhao 評(píng)論0 收藏0
  • 嚼一嚼event loop

    摘要:設(shè)計(jì)為單線程設(shè)計(jì)為單線程還是跟他的用途有關(guān)試想一下如果設(shè)計(jì)為多線程那么同時(shí)修改和刪除同一個(gè)瀏覽器又該如何執(zhí)行需要異步我在執(zhí)行但用戶不知道你好啊上圖例子循環(huán)耗時(shí)會(huì)很久這意味著用戶得不到你好啊的響應(yīng)就會(huì)下意識(shí)會(huì)認(rèn)為瀏覽器卡死了所以必須要有異步通 js設(shè)計(jì)為單線程 js設(shè)計(jì)為單線程還是跟他的用途有關(guān) 試想一下 如果js設(shè)計(jì)為多線程 那么同時(shí)修改和刪除同一個(gè)dom 瀏覽器又該如何執(zhí)行? sh...

    wangtdgoodluck 評(píng)論0 收藏0
  • __proto__和prototype

    摘要:屬性對(duì)性能影響非常嚴(yán)重,不建議使用。當(dāng)你創(chuàng)建函數(shù)時(shí),會(huì)為這個(gè)函數(shù)自動(dòng)添加屬性。構(gòu)造函數(shù)原型的默認(rèn)指向自身。所有對(duì)象均從繼承屬性。結(jié)果見下圖普通對(duì)象是構(gòu)造函數(shù)的實(shí)例,所以普通對(duì)象的原型是??偨Y(jié)和其它函數(shù)由產(chǎn)生,的是他自己。 _proto_ 每個(gè)對(duì)象都有一個(gè)__proto__(前后各兩個(gè)下劃線)屬性來(lái)標(biāo)識(shí)自己所繼承的原型對(duì)象。__proto__屬性對(duì)性能影響非常嚴(yán)重,不建議使用。 pro...

    raise_yang 評(píng)論0 收藏0
  • 淺析webpack源碼之Stat.js粗解(十)

    摘要:從出來(lái)接著我們看大法,打印一下感覺之前所以的對(duì)象都放在了一個(gè)合集里,給人而全的感覺里面主要含有一個(gè)對(duì)象,,輸出的,等給每次打包一個(gè)值,代表唯一性天啊 從compilation出來(lái)接著我們看 const stats = new Stats(compilation); Stats.js log大法,打印一下 stats let Stats = { compilation:{ ...

    Andrman 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<