国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

ES6字符串模板,剩余參數,默認參數功能與用法示例

2019-11-19 16:55:02
字體:
來源:轉載
供稿:網友

本文實例講述了ES6字符串模板,剩余參數,默認參數功能與用法。分享給大家供大家參考,具體如下:

這里介紹一下字符串模板以及剩余參數,默認參數的概念以及使用。
先來說說字符串模板。

字符串模板

ES6中允許使用反引號 ` 來創建字符串,此種方法創建的字符串里面可以包含由美元符號加花括號包裹的變量${varible}。如果你使用過像C#等后端強類型語言的話,對此功能應該不會陌生。

//產生一個隨機數var num=Math.random();//將這個數字輸出到consoleconsole.log(`your num is ${num}`);

可以看出來,字符串模板其實就是將JavaScript中常用的字符串拼接變得更加簡單了一些。但是其實它還有一些不易讓人察覺的作用:

1. 模板中可以繼續套入一個模板;

2. 如果一個變量不是字符串,通過字符串模板它會變成字符串,就好像調用了.toString()方法一樣;

但是同樣的,有一些事情它也做不了:

1. 它不能自動轉義,所以為了防止CORS攻擊,我們還是要小心處理一些敏感數據;

2. 它不是用來取代其他js模板的,因為它沒有關于循環的相關語法,而這些是其他js模板擅長的。

下圖是字符串模板的使用示例:

可以看到字符串模板中還可以解析函數,并且可以帶參數。

剩余參數

接下來說說剩余參數,很多語言早就實現了剩余參數了。剩余參數說來了就是用來取代arguments的。

大家應該知道arguments吧,作為javascript函數中的默認屬性,arguments代表了所有的參數。

arguments功能雖然強大,但是容易讓人疏忽從而造成不必要的錯誤。我們舉一個例子,我們先一個簡單的驗證函數containsAll ,其作用是檢測第一個參數中是否包含后面幾個參數。

比如:

containsAll("banana", "b", "nan") //會返回 true,containsAll("banana", "c", "nan") //會返回 false。

實現代碼如下:

function containsAll(haystack) { for (var i = 1; i < arguments.length; i++) {  var needle = arguments[i];  if (haystack.indexOf(needle) === -1) {   return false;  } } return true;}

可以看到我們用到了arguments對象,但是它的下標我們是從1開始的,如果從0開始就會選中haystack了,所以不能選擇0,而這里就最容易出錯。

那么我們看看用ES6的剩余參數如何來實現這個方法:

function containsAll(haystack, ...needles) { for (var needle of needles) {  if (haystack.indexOf(needle) === -1) {   return false;  } } return true;}

可以看到剩余參數…的特定語法。也就是說,所有第2到第n個參數現在可以直接放到…后面的數組中去了。

…的用法可不僅僅局限于函數的參數噢,還可以用來簡化:

var a = [2,3,4];var b = [ 1, ...a, 5 ];console.log( b );// [1,2,3,4,5]

默認參數

再來談談默認參數,默認參數也早就被很多語言所實現,其實是一個很基本的功能:

function animalSentence(animals2="tigers", animals3="bears") {  return `Lions and ${animals2} and ${animals3}! Oh my!`;}

不同的參數會返回不同的結果:

animalSentence()//"Lions and tigers and bears! Oh my!";animalSentence("elephants") //"Lions and elephants and bears! Oh my!"animalSentence("elephants", "whales")//"Lions and elephants and whales! Oh my!".

但是javascript的默認參數功能可不只這么簡單,它還可以進行簡短的表達式:

function animalSentenceFancy(animals2="tigers",animals3=(animals2 == "bears") ? "sealions" : "bears"){ return `Lions and ${animals2} and ${animals3}! Oh my!`;}

希望本文所述對大家ECMAScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 龙海市| 镇江市| 三穗县| 白山市| 南溪县| 新密市| 赣榆县| 惠来县| 肥西县| 金乡县| 广州市| 泸溪县| 太谷县| 荔波县| 叶城县| 比如县| 滁州市| 团风县| 博爱县| 蒙阴县| 壶关县| 宁海县| 郎溪县| 无为县| 崇礼县| 开阳县| 平南县| 宁德市| 池州市| 沅陵县| 巴塘县| 高阳县| 永城市| 宁明县| 盐源县| 南召县| 南平市| 仁寿县| 拜泉县| 姚安县| 青田县|