ES6語法:函數新特性(一)

来源:https://www.cnblogs.com/swzx-1213/archive/2020/04/03/12628164.html
-Advertisement-
Play Games

ES6 函數 引言: 函數在任何語言中偶讀很重要,java裡面的函數通常叫做方法,其實是一個東西,使用函數可以簡化更多的代碼,代碼結構看著更加清晰。今天我們來學學ES6語法中,函數有什麼變化。 雖然現在的有比ES6更高的版本,但是主流一般都是ES6。es6中的函數相對於之前的版本提升了很多,相對來說 ...


ES6 函數

引言:

函數在任何語言中偶讀很重要,java裡面的函數通常叫做方法,其實是一個東西,使用函數可以簡化更多的代碼,代碼結構看著更加清晰。今天我們來學學ES6語法中,函數有什麼變化。

雖然現在的有比ES6更高的版本,但是主流一般都是ES6。es6中的函數相對於之前的版本提升了很多,相對來說在某些特定條件下,用新的函數很方便,也更簡潔,功能性更加強大。

1.帶參數預設值的函數。

我們都知道js是弱類型語言,不知道你有沒有試過,或者學到過,js的函數聲明過後,在調用這個函數的時候可以忽略這個函數所帶的參數,就是說,聲明的這個函數原本是帶有參數的,但是呢,我在調用的時候是不需要傳參的,這樣也不會報錯,而那些參數會有一個預設的值。來看看代碼。

function testParameter(parameter1,parameter2){
	console.log(parameter1);
	console.log(parameter2);
}
testParameter();

這個是可以運行的,不會報錯的,結果是什麼呢?兩個都是undefined。這就是弱類型語言的特點之一,與java不同,java會強制要求你輸入參數。
一般來說,我們在實際項目中,如果有這種用法的話,這些參數都是有用的也就是需要參數有一個預設值。在es6之前,如果沒有傳參數,而且這個參數又是需要用到的,需要一個預設值,我們都需要自己判斷這個參數是不是undefined,然後給這個參數設置預設值。這樣自己寫代碼就比較麻煩。因此在es6的時候,函數可以這樣聲明,給函數的參數設置一個預設值。

function defaultParameter(parameter1,parameter2=30){
    console.log(parameter1);
    console.log(parameter2);
}
defaultParameter();

這樣我們就給parameter2設置了一個預設的值為30,parameter1還是為undefined,雖然這種函數調用可以不傳參數,我建議這個時候,這個沒有設置預設值的參數還是儘量要傳。參數的類型可以是任意類型,可以是字元串,數字,函數,對象,都可以設置一個預設的值。
還有一種情況,
如下:

function defaultParameter1(parameter1="這是第一個參數",parameter2){
	return parameter1+parameter2;
}

console.log(defaultParameter1());

這段代碼列印出來的是“這是第一個參數undefined”,然後我們傳一個參數。

function defaultParameter1(parameter1="這是第一個參數",parameter2){
	return parameter1+parameter2;
}

console.log(defaultParameter1(20));

你猜現在的結果是什麼?你可能會說"20undefined",但是結果真不是這個,結果是"NaN",為什麼?,仔細的同學就發現了,我們傳的是一個20,而不是“20”,這個數字20和undefined相加的結果就成了NaN。當我們傳“20”的時候,答案就是“20undefined”,但是我想說的是,如果這時我不想傳第一個值怎麼辦,我想穿第二個值。往下看。

function defaultParameter1(parameter1="這是第一個參數",parameter2){
	return parameter1+parameter2;
}

console.log(defaultParameter1(undefined,"這是第二個參數"));

把第一個參數設置成undefined就行了,並且只有設置成undefined才能使用預設的第一個參數,然後順利給第二個值設置參數值。

2.參數預設值為表達式的函數。

前面說了帶有預設值參數的函數,這節就為你帶來,參數是表達式

來來來看代碼

function expression(name,address=getStr()){
	console.log(name+address);
}
function getStr(){
	return "全棧學習筆記!"
}
expression("wx search");

這樣也是可行的,結果你懂的,哈哈,如果你覺得能學到不少知識,就試試這個結果,精彩美文每天為你推送!
這裡其實有一個有趣的,看下麵;

function expression(name,address=name){
	console.log(name+address);
}
function getStr(){
	return "全棧學習筆記!"
}
expression("全棧學習筆記");

這樣也是可以的,結果就是會列印出來兩個“全棧學習筆記”,然後看看這個

function expression(name=address,address){
	console.log(name+address);
}
function getStr(){
	return "全棧學習筆記!"
}
expression(undefined,"全棧學習筆記");

我們將這個接收表達式的參數放在前面,就是相當於上面哪一種情況反過來,這樣是不行的哦!
這一期的函數知識就分享到這,下一期將繼續分享函數這一塊的知識!如果你發現文中有什麼錯誤或者對我有什麼建議可以私信我哦!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、ListView 該組件是android中最常用的一個UI組件,用於實現在屏幕上顯示​多個內容,以便於我們用手指來回翻轉。 先在layout中進行佈局我們的組件 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/and ...
  • 對初學者來說,看完這篇文章,我想你腦瓜子一定是嗡嗡的,這都說的是什麼啊。 不要急躁,開始的我和你是一樣的,第一遍看完,完全不知道在說什麼,不明白不要緊,請先收藏此文章,然後先去學習下Flutter內置的25種動畫組件。 地址: "http://laomengit.com/flutter/module ...
  • 網站主題灰度顯示 在style.css文件頂端添加下行代碼即可 ​ 2020開年一切都是那麼的不平凡,這段時間我見證了太多的不可思議:修建”火神山“、”雷神山“醫院,大批醫療人員志願者奔赴湖北;各國政府及組織捐贈防控物資;各地省內省際長途關閉、火車實行隔座,航班限次;封城封村封小區;各地實行健康碼, ...
  • 本文直接從防禦方式開始討論,防禦CSRF有4種方法: 使用POST替代GET 檢驗HTTP Referer 驗證碼 Token 使用POST替代GET 一些程式員在開發的時候都是用GET、POST通用的函數來接收客戶端的數據,這樣也是某些介面有CSRF的原因之一,但是將全部介面都改成只允許POST方 ...
  • 接上篇 https://www.cnblogs.com/chenyingying0/p/12612393.html Loading組件 在api--home.js中,添加代碼,使ajax獲取到輪播圖數據後,延遲一秒再顯示 import axios from 'axios'; import {SUCC ...
  • demo 商城後臺,添加一種商品 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title></title> <!-- 引入vue.js --> <script src="js/vue.js"></script> </head> <b ...
  • ```javascript ``` ![在這裡插入圖片描述](https://img-blog.csdnimg.cn/20200403222109559.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text... ...
  • 嵌套路由 嵌套路由:一個路由配置中嵌套其他的路由配置。 嵌套路由挺常用的,比如導航欄有首頁、文章、想法、留言4個模塊,我們以嵌套路由的形式集成這些模塊,在導航欄中點擊對應的條目,就會路由到對應的頁面(下方顯示對應的頁面),和html的<iframe>效果差不多。 demo 嵌套路由 <!DOCTYP ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...