整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          JavaScript 函數

          JavaScript 函數

          avaScript 函數定義

          JavaScript 使用關鍵字 function 定義函數

          函數可以通過聲明定義,也可以是一個表達式

          函數聲明

          函數聲明的語法 :

          函數聲明后不會立即執行,會在我們需要的時候調用到

          分號是用來分隔可執行JavaScript語句,由于函數聲明不是一個可執行語句所以不以分號結束

          函數表達式,又叫函數字面量

          JavaScript 函數可以通過一個表達式定義

          函數表達式可以存儲在變量中:

          在函數表達式存儲在變量后,變量也可作為一個函數使用:

          兩者的區別:解析器會先讀取函數聲明,并使其在執行任何代碼之前可以訪問;而函數表達式則必須等到解析器執行到它所在的代碼行才會真正被解釋執行。

          以上函數實際上是一個 匿名函數 (函數沒有名稱)。函數存儲在變量中,不需要函數名稱,通常通過變量名來調用。上述函數以分號結尾,因為它是一個執行語句。

          函數的幾種寫法

          1 常見寫法:

          2 匿名函數

          3 自調用函數:

          4 函數嵌套

          5 函數繼承和構造函數

          Function() 構造函數

          在以上實例中,我們了解到函數通過關鍵字 function 定義。函數同樣可以通過內置的 JavaScript 函數構造器(Function())定義

          實際上,你不必使用構造函數。上面實例可以寫成:

          在 JavaScript 中,很多時候,你需要避免使用 new 關鍵字

          函數提升(Hoisting)

          提升(Hoisting)是 JavaScript 默認將當前作用域提升到前面去的的行為。

          提升(Hoisting)應用在變量的聲明與函數的聲明,因此,函數可以在聲明之前調用:

          使用表達式定義函數時無法提升

          以上代碼運行即會報錯,原因在于函數位于一個初始化語句中,而不是一個函數聲明。換句話講,在執行到函數所在的語句之前,變量myFunction中不會保存有對函數的引用;而且,由于第一行代碼就會導致“unexpected identifier”(意外標識符)錯誤,實際上也不會執行到下一行。

          除了聲明時候可以通過變量訪問函數這一點區別之外,函數聲明與函數表達式的語法其實是等價的。

          自調用函數

          函數表達式可以 "自調用"。自調用表達式會自動調用。如果表達式后面緊跟 () ,則會自動調用。不能自調用聲明的函數。通過添加括號,來說明它是一個函數表達式:

          以上函數實際上是一個 匿名自我調用的函數

          自調用函數可用來傳參帶返回值

          自執行函數嚴格來說也叫函數表達式,它主要用于創建一個新的作用域,在此作用域內聲明的變量,不會和其它作用域內的變量沖突或混淆,大多是以匿名函數方式存在,且立即自動執行。

          JavaScript函數可作為一個值使用

          JavaScript函數可作為表達式使用:

          函數是對象

          在 JavaScript 中使用 typeof 操作符判斷函數類型將返回 "function" ,但JavaScript 函數描述為一個對象更加準確。

          JavaScript 函數有屬性和方法。

          arguments.length 屬性返回函數調用過程接收到的參數個數:

          toString() 方法將函數作為一個字符串返回:

          函數定義作為對象的屬性,稱之為對象方法。

          函數如果用于創建新的對象,稱之為對象的構造函數

          JavaScript 函數參數

          JavaScript 函數對參數的值(arguments)沒有進行任何的檢查

          函數顯式參數與隱藏參數(arguments)

          函數顯式參數在函數定義時列出

          函數隱藏參數(arguments)在函數調用時傳遞給函數真正的值

          參數規則

          JavaScript 函數定義時參數沒有指定數據類型,對隱藏參數(arguments)沒有進行檢測,對隱藏參數(arguments)的個數沒有進行檢測

          默認參數

          如果函數在調用時缺少參數,參數會默認設置為: undefined

          有時這是可以接受的,但是建議最好為參數設置一個默認值:

          或者,更簡單的方式:

          如果y已經定義, y || 返回y, 因為y是 true, 否則返回 0, 因為undefined為 false

          如果函數調用時設置了過多的參數,參數將無法被引用,因為無法找到對應的參數名。 只能使用 arguments 對象來調用

          Arguments 對象

          JavaScript 函數有個內置的對象 arguments 對象。arguments 對象包含了函數調用的參數數組。通過這種方式你可以很方便的找到每個參數的值:

          或者創建一個函數用來統計所有數值的和:

          通過值傳遞參數

          在函數中調用的參數是函數的參數。

          如果函數修改參數的值,將不會修改參數的初始值(在函數外定義)。

          通過對象傳遞參數

          在JavaScript中可以引用對象的值,因此我們在函數內部修改對象的屬性就會修改其初始的值。

          修改對象屬性可作用于函數外部(全局變量)。

          JavaScript 函數調用

          JavaScript 函數有 4 種調用方式。每種方式的不同方式在于 this 的初始化

          this 關鍵字

          一般而言,在Javascript中,this指向函數執行時的當前對象

          注意 this 是保留關鍵字,你不能修改 this 的值

          調用 JavaScript 函數

          函數中的代碼在函數被調用后執行

          作為一個函數調用

          以上函數不屬于任何對象。但是在 JavaScript 中它始終是默認的全局對象。

          在 HTML 中默認的全局對象是 HTML 頁面本身,所以函數是屬于 HTML 頁面。

          在瀏覽器中的頁面對象是瀏覽器窗口(window 對象)。以上函數會自動變為 window 對象的函數

          myFunction() 和 window.myFunction() 是一樣的:

          這是調用 JavaScript 函數常用的方法, 但不是良好的編程習慣。全局變量,方法或函數容易造成命名沖突的bug

          全局對象

          當函數沒有被自身的對象調用時, this 的值就會變成全局對象。

          在 web 瀏覽器中全局對象是瀏覽器窗口(window 對象)。

          該實例返回 this 的值是 window 對象:

          函數作為全局對象調用,會使 this 的值成為全局對象。使用 window 對象作為一個變量容易造成程序崩潰

          函數作為方法調用

          在 JavaScript 中你可以將函數定義為對象的方法。

          以下實例創建了一個對象 (myObject), 對象有兩個屬性 (firstName 和 lastName), 及一個方法 (fullName):

          ullName 方法是一個函數。函數屬于對象。 myObject 是函數的所有者。

          this對象,擁有 JavaScript 代碼。實例中 this 的值為 myObject 對象。

          測試以下!修改 fullName 方法并返回 this 值:

          函數作為對象方法調用,會使得 this 的值成為對象myObject本身

          使用構造函數調用函數,參數必須加引號

          如果函數調用前使用了 new 關鍵字, 則是調用了構造函數。這看起來就像創建了新的函數,但實際上 JavaScript 函數是重新創建的對象:

          構造函數的調用會創建一個新的對象。新對象會繼承構造函數的屬性和方法

          構造函數中 this 關鍵字沒有任何的值。this 的值在函數調用時實例化對象(new object)時創建。

          作為函數方法調用函數

          在 JavaScript 中, 函數是對象。JavaScript 函數有它的屬性和方法。call() 和 apply() 是預定義的函數方法。 兩個方法可用于調用函數,兩個方法的第一個參數必須是對象本身。

          兩個方法都使用了對象本身作為第一個參數。 兩者的區別在于第二個參數: apply傳入的是一個參數數組,也就是將多個參數組合成為一個數組傳入,而call則作為call的參數傳入(從第二個參數開始)。call和apply的第一個參數就是this指針要指向的對象

          在 JavaScript 嚴格模式(strict mode)下, 在調用函數時第一個參數會成為 this 的值, 即使該參數不是一個對象。

          在 JavaScript 非嚴格模式(non-strict mode)下, 如果第一個參數的值是 null 或 undefined, 它將使用全局對象替代。

          通過 call() 或 apply() 方法你可以設置 this 的值, 且作為已存在對象的新方法調用

          JavaScript 閉包

          JavaScript 變量可以是局部變量或全局變量

          私有變量可以用到閉包

          局部變量和全局變量

          函數可以訪問函數內部定義的變量

          函數也可以訪問函數外部定義的變量

          后面一個實例中, a 是一個全局變量。在web頁面中全局變量屬于 window 對象。全局變量可應用于頁面上的所有腳本。

          在第一個實例中, a是一個局部變量。局部變量只能用于定義它函數內部。對于其他的函數或腳本代碼是不可用的。全局和局部變量即便名稱相同,它們也是兩個不同的變量。修改其中一個,不會影響另一個的值。

          變量聲明是如果不使用 var 關鍵字,那么它就是一個全局變量,即便它在函數內定義

          變量生命周期

          全局變量的作用域是全局性的,即在整個JavaScript程序中,全局變量處處都在。而在函數內部聲明的變量,只在函數內部起作用。這些變量是局部變量,作用域是局部性的;函數的參數也是局部性的,只在函數內部起作用。

          計數器困境

          設想下如果你想統計一些數值,且該計數器在所有函數中都是可用的。你可以使用全局變量,函數設置計數器遞增:

          計數器數值在執行 add() 函數時發生變化。但問題來了,頁面上的任何腳本都能改變計數器,即便沒有調用 add() 函數。如果我在函數內聲明計數器,如果沒有調用函數將無法修改計數器的值:

          以上代碼將無法正確輸出,每次我調用 add() 函數,計數器都會設置為 1。JavaScript 內嵌函數可以解決該問題

          JavaScript 內嵌函數

          所有函數都能訪問全局變量。 實際上,在 JavaScript 中,所有函數都能訪問它們上一層的作用域。JavaScript 支持嵌套函數。嵌套函數可以訪問上一層的函數變量。

          該實例中,內嵌函數 plus() 可以訪問父函數的 counter 變量:

          如果我們能在外部訪問 plus() 函數,這樣就能解決計數器的困境。我們同樣需要確保 counter=0 只執行一次。我們需要閉包。

          JavaScript 閉包

          變量 add 指定了函數自我調用的返回字值。自我調用函數只執行一次。設置計數器為 0。并返回函數表達式。add變量可以作為一個函數使用。非常棒的部分是它可以訪問函數上一層作用域的計數器。這個叫作 JavaScript 閉包。它使得函數擁有私有變量變成可能。計數器受匿名函數的作用域保護,只能通過 add 方法修改。

          閉包是可訪問上一層函數作用域里變量的函數,即便上一層函數已經關閉

          歡迎加油QQ群461593224 web前端 學習交流

          數(Function)是被設計為執行特定任務的代碼塊。它在可以實現定制運算功能的同時,還帶有一個入口和一個出口。所謂的入口,就是函數所帶的各個參數,我們可以通過這個入口,把函數的參數值代入子程序,供計算機處理;所謂出口,就是指函數的函數值,在計算求得結果之后,由此口帶回給調用它的程序。

          在程序設計中,常將一些常用的功能模塊編寫成函數,放在函數庫中供用戶選用。善于利用函數,可以減少重復編寫程序段的工作量。

          本文介紹Javascript函數的幾種常用定義方式。掌握JS函數基本技術后,在統計數據處理過程中,我們將函數理解為某一統計對象(項目)所定制的方法。

          導讀:

          • 普通函數
          • 函數arguments對象
          • 匿名函數
          • 閉包和遞歸函數
          • Promise回調函數

          1、普通函數

          I、基本語法

          function 函數名稱(參數1, 參數2, 參數3) {
          		//要執行的代碼
          return 返回值
          }

          JavaScript函數語法解析如下:

          • JavaScript函數通過function關鍵詞進行定義,其后是函數名稱和括號()
          • 函數名可包含字母、數字、下劃線和美元符號
          • 圓括號可包括由逗號分隔的參數
          • 由函數執行的代碼被放置在花括號{}中
          • 函數返回值由return關鍵字指定

          II、無參數函數

          console.clear();
          function test1() {
          return "Hello World!";
          }
          //執行函數返回"Hello World!",并賦值給變量str
          var str=test1();
          console.log(str);

          注:Console對象用于JavaScript調試,為了顯示Console.log輸出結果,通過按Control+Shift+i(PC平臺)來打開Console窗口

          III、有參數函數

          //計算任意兩個數的和
          function oSum(x, y) {
          return x+y;
          }
          var mySum=oSum(15, 85);
          console.log(mySum); //100

          IV、參數默認值設置

          //求和函數中給兩個參數設置默認值
          console.clear();
          function oSum(x=50, y=50) {
          return x+y;
          }
          var mySum=oSum(15, 55);
          console.log(mySum); //70
          mySum=oSum(15);
          console.log(mySum); //65
          mySum=oSum();
          console.log(mySum); //100

          V、參數為函數

          console.clear();
          function oSum(x, y) {return x+y;}
          var mySum=oSum(oSum(45, 75), 100);
          console.log(mySum); //220

          VI、對象{}為參數 - 解構賦值默認值

          console.clear();
          function oSum({x=10, y=20}) {
          return x+y;
          }
          console.log(oSum({})); //30,這里直接調用oSum()出錯
          console.log(oSum({x:100})); //120
          console.log(oSum({y:100})); //110
          console.log(oSum({x:100,y:200})); //300
          console.log(oSum({y:50,x:20})); //70

          VII、對象{}為參數 - 雙重默認值

          //代碼容錯更好
          console.clear();
          function oSum({x=10, y=20}={}) {
          return x+y;
          }
          console.log(oSum()); //30
          console.log(oSum({})); //30
          console.log(oSum({x:100})); //120
          console.log(oSum({y:100})); //110
          console.log(oSum({x:100,y:200})); //300
          console.log(oSum({y:50,x:20})); //70

          2、函數arguments對象

          在JavaScript中,參數在函數內部是以一個數組表示的,arguments是函數內部的一個專門用來存儲實參的數組對象。函數arguments的對象在函數運行時用于檢測和重新設置參數。

          I、arguments.length - 函數參數數量

          console.clear();
          function fn(a,b,c){
          console.log(arguments.length); //3
          return a+b+c;
          }
          console.log(fn(1,2,3)); //6

          II、arguments[] - 函數輸出和設置

          console.clear();
          function fn(a,b,c){
          console.log(arguments[0]); //1
          console.log(arguments[1]); //2
          console.log(arguments[2]); //3
          arguments[0]=5; //重新設置參數a=5
          return a+b+c;
          }
          console.log(fn(1,2,3)); //10

          III、arguments轉數組

          arguments對象不是一個真正的數組 ,它類似于數組,但除了length屬性和索引元素之外沒有任何數組屬性。例如,它沒有pop方法。但是它可以被轉換為一個真正的數組,轉換為真實的數組后就可以使用完整的數組方法

          console.clear();
          function fn(a, b, c) {
          var arr=Array.from(arguments); //進行轉數組操作
          console.log(arr); //輸出數組
          return a + b + c;
          }
          console.log(fn(1, 2, 3)); //6

          3、匿名函數

          匿名函數顧名思義指的是沒有名稱的函數,在實際開發中使用的頻率非常高,是學好JS編程的重點。

          I、變量匿名函數

          console.clear();
          var fn=function fn(a,b,c=9) {
          return a+b+c;
          }
          console.log(fn(1,2)); //12
          console.log(fn(1,2,3)); //6

          II、無名稱匿名函數

          即在函數聲明時,在后面緊跟參數。JS語法解析此函數時,里面代碼立即執行。

          console.clear();
          console.log(function(a,b){return a+b;}(2,3));
          console.clear();
          //加括號執行無匿名函數(輸出"Hello Word!")
          (function (){
          		console.log("Hello Word!");
          })()
          //加括號執行有匿名函數(輸出"Hello Word! lei.")
          (function (str){
          		console.log("Hello Word!" +" "+ str +".");
          })("lei")

          注:函數代碼function(a,b){return a+b;}沒指定函數名稱,如果需要執行匿名函數,在匿名函數后面加上一個括號即可立即執行

          III、事件綁定匿名函數

          通常我們瀏覽網頁時會通過鼠標或鍵盤輸入信息,例如鼠標點擊某個按鈕稱“click點擊事件”、文本框內文字信息改變了稱“change事件”。總之,用戶所有的鼠標、鍵盤操作都稱為事件,都可以通過JS代碼來捕獲這些事件。

          console.clear();
          //通過id或取圖標對象
          var logo=document.querySelector("#myLogo");
          //給左上角“銀河統計”圖標增加點擊事件
          logo.onclick=function(){
          		console.log("歡迎來到銀河統計工作室!");
          }
          logo.onmousemove=function(){
              logo.style.cursor="pointer";
              console.log("鼠標在圖像上面!");
          }
          logo.onmouseout=function(){
              logo.style.cursor="default";
              console.log("鼠標已經離開圖像!");
          }

          注:代碼中網頁圖像標記為<img id="myLogo" src="###"/>

          IV、對象綁定匿名函數做為對象的方法

          前面我們介紹JS對象時提到,事件是有屬性和方法組成的數據結構,事件的方法可以通過綁定匿名函數的方式建立。

          console.clear();
              var obj={
              name:"Carolyn",
              age:11,
              fn:function(str){
              		return "My name is "+this.name+" Siyu"+". I'm "+this.age+" years old now.";
              }
          };
          console.log(obj.fn("Siyu")); //My name is Carolyn Siyu. I'm 11 years old now.

          注:這里定匿名函數為屬性的返回值

          V、匿名函數做為回調函數(callback)

          什么是同步,什么是異步?

          同步指的是一次只能完成一件任務。如果有多個任務,就必須排隊,前面一個任務完成,再執行后面一個任務,以此類推。

          異步指的是每一個任務有一個或多個回調函數(callback),前一個任務結束后,不是執行后一個任務,而是執行回調函數,后一個任務則是不等前一個任務結束就執行,所以程序的執行順序與任務的排列順序是不一致的、異步的。

          JS是單線程的,它本身不可能是異步的,通過回調函數可以實現異步。JS中最基礎的異步是setTimeout和setInterval函數。

          console.clear();
          var interval=setInterval(function(){
          		console.log("回調函數,每間隔1秒鐘會被執行一次");
          },1000);
          //點擊銀河統計圖表停止setInterval計算器運行
          var logo=document.querySelector("#myLogo");
          logo.onclick=function(){
              console.log("Stop!");
              clearInterval(interval)
          }
          setTimeout(function() {
          		console.log("張三")
          }, 1000 );
          setTimeout(function() {
          		console.log("李四")
          }, 2000 );
          setTimeout(function() {
          		console.log("王五")
          }, 3000 );
          //jS最基礎的異步實現
          function a() {
              console.log("執行a函數");
              setTimeout(function() {
              		console.log("執行a函數的延遲函數");
              },2000);
          }
          function b() {
          		console.log("執行b函數");
          }
          a();
          b();

          VI、匿名函數做為返回值

          console.clear();
          function fn(){
              return function(){
              		return "Carolin";
              }
          }
          //調用匿名函數
          console.log(fn()()); //Carolin
          //或者
          var box=fn();
          console.log(box()); //Carolin

          4、閉包和遞歸函數

          假設,函數A內部聲明了個函數B,函數B引用了函數B之外的變量,并且函數A的返回值為函數B的引用,那么函數B就是閉包函數。

          遞歸就是函數自己調用自己,當函數自己時,其自身為閉包函數,參數為域外變量。

          console.clear();
          function funA(arg1,arg2) {
              var i=0; //funA作用域的變量
              function funB(step) {
                  i=i + step; //訪問funB作用域外變量i
                  console.log(i)
              }
              return funB;
          }
          var allShowA=funA(2, 3); //調用的是funA arg1=2,arg2=3
          allShowA(1);//調用的是funB step=1,輸出 1
          allShowA(3);//調用的是funB setp=3,輸出 4
          //累加
          console.clear();
          function f(num){
              if(num<1) {
             		 return 0;
              } else {
              		return f(num-1)+num;
              }
          }
          console.log(f(9)); //45
          //階乘
          console.clear();
          function f(num){
              if(num<1) {
              return 1;
              } else {
              return f(num-1)*num;
              }
          }
          console.log(f(4)); //24
          //在對象中定義遞歸方法
          var obj={
              num : 5,
              fac : function (x) {
                  if (x===1) {
                  		return 1;
                  } else {
                  		return x * obj.fac(x - 1);
                  }
              }
          };
          console.log(obj.fac(5)) /120
          //使用arguments.callee
          function fact(num){
              if (num<=1){
              		return 1;
              }else{
             		 return num*arguments.callee(num-1);
              }
          }
          console.log(fact(4)); //24

          5、Promise回調函數

          Promise是ES6語言標準中提供的對象。Promise是異步編程的一種解決方案,比傳統的解決方案(回調函數和事件)更合理和更強大。

          console.clear();
          //基本用法,
          var p=new Promise(function(resolve, reject){
              setTimeout(function(){
              		resolve(console.log("done"));
              }, 1000);
          });
          //做為對象返回
          function timeout(ms) {
              return new Promise((resolve, reject)=> {
              		setTimeout(resolve, ms, 'done');
              });
          }
          timeout(1000).then((value)=> { //參數value='done'
          		console.log(value);
          });
          //完整使用方法
          function promiseTest(){
          let p=new Promise(function(resolve, reject){
              setTimeout(function(){
                  var num=Math.random()*100; //生成1-100的隨機數
                  console.log('隨機數生成的值:',num)
                  if(num>=60){
                      resolve(num);
                  } else {
                      reject('數字太于60了即將執行失敗回調');
                  }
                  }, 2000);
              })
              return p
          }
          promiseTest().then(
              function(data){ //data=num
                  console.log('resolved成功回調');
                  console.log('成功回調接受的值:',data);
              }
          )
          .catch(function(reason, data){
              console.log('catch到rejected失敗回調');
              console.log('catch失敗執行回調拋出失敗原因:',reason);
          });

          注:Promise回調函數在網頁數據抓取時常常遇到

          JavaScript是一種面向對象的編程語言,因此對象在JavaScript中扮演了很重要的角色。

          Javascript函數是能完成某個常用功能的一小段代碼,而Javascript方法(method)是通過對象調用的Javascript函數。

          JS中所有事物都是對象,對象是擁有屬性和方法的數據。但是,JS對象又是由函數創建的,JS函數本身也是對象。“方法是函數、對象是函數”,JS中函數的用途和含義有點繞口,需要大量練習和運用才能掌握。

          數的定義方式


          1. 函數聲明方式 function 關鍵字 (命名函數)


          2. 函數表達式 (匿名函數)


          3. new Function()

          Function 里面參數都必須是字符串格式


          第三種方式執行效率低,也不方便書寫,因此較少使用


          所有函數都是 Function 的實例(對象)


          函數也屬于對象


          函數的調用方式


          1. 普通函數


          function fn() {


          console.log('人生的巔峰');


          }


          fn(); fn.call()


          2. 對象的方法


          var o={


          sayHi: function() {


          console.log('人生的巔峰');


          }


          }


          o.sayHi();


          3. 構造函數


          function Star() {};


          new Star();(構造函數和普通函數肯定不一樣了,他們的主要區別是構造函數首字母大寫,還有就是new關鍵字調用)


          4. 綁定事件函數


          btn.onclick=function() {}; // 點擊了按鈕就可以調用這個函數


          5. 定時器函數


          setInterval(function() {}, 1000); 這個函數是定時器自動1秒鐘調用一次


          6. 立即執行函數


          (function() {


          console.log('人生的巔峰');


          })();


          立即執行函數是自動調用


          主站蜘蛛池模板: 国产福利一区视频| 亚洲熟妇av一区二区三区漫画| 69久久精品无码一区二区| 国模无码人体一区二区| 国产AV一区二区三区无码野战| 久久精品国产一区二区三区不卡| 国产内射999视频一区| 亚洲一区二区三区无码国产| 一本大道在线无码一区| 国产在线一区二区三区av| 久久久不卡国产精品一区二区| 一区二区在线免费观看| 亚洲av日韩综合一区二区三区| 日本精品一区二区三区在线视频一| 精品一区二区三区在线观看l | 国产精品成人一区无码 | 无码人妻久久一区二区三区| 亚洲高清成人一区二区三区| 亚洲一区二区三区高清| 精品国产aⅴ无码一区二区| 欧洲精品码一区二区三区免费看| 伊人久久大香线蕉av一区| 成人精品视频一区二区| 国偷自产av一区二区三区| 亚洲影视一区二区| 国产伦精品一区二区三区免.费| 亚洲一区二区三区影院 | 国产一区二区三区电影| 色窝窝无码一区二区三区成人网站| 国产精品无码一区二区在线| 中文字幕亚洲综合精品一区| 日韩精品一区二区三区中文字幕| 亚洲午夜一区二区三区| 无码一区二区三区| 日韩精品无码一区二区中文字幕| 国产波霸爆乳一区二区| 中文字幕人妻丝袜乱一区三区 | 武侠古典一区二区三区中文| 麻豆aⅴ精品无码一区二区| 日韩一区二区久久久久久| 91一区二区三区|