本文實(shí)例講述了ES6學(xué)習(xí)筆記之新增數(shù)據(jù)類型。分享給大家供大家參考,具體如下:
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比慶云網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式慶云網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋慶云地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。
基本用法:let [key1,key2...]=[value1,value2...]
let [name,age,sex]=['小明',24,'男']; console.log(name); console.log(age); console.log(sex);
注意左右的key與value格式要匹配對應(yīng),鍵值可以缺省,但逗號(hào)的位置要正確
let [arr1,,[arr3,,[,arr6]]]=[1,2,[31,32,[331,332]]]; console.log(arr1); console.log(arr3); console.log(arr6);
用法:let {key1,key2...}={key1:value1,key2:value2...}
let obj={name:'小明',age:24,sex:'男',friend:['小張','小李']}; console.log(obj.name); console.log(obj.age); console.log(obj.sex); console.log(obj.friend);
字符串中每個(gè)字符與數(shù)組鍵對應(yīng)
let [a,b,c]="這是一個(gè)字符串"; console.log(a); console.log(b); console.log(c);
set與數(shù)組不同在于set中不可以有重復(fù)數(shù)據(jù),常用于去重操作
let myset=new Set(['data1','data2','data3','data3']);
console.log(myset.size);
myset.add('data4');//增加元素 myset.delete('data2');//刪除元素 console.log(myset.has('data1'));//判斷是否含有某個(gè)元素,包含返回true myset.clear();//清除集合所有元素 console.log(myset.keys());//返回集合所有的鍵值 console.log(myset.values());//返回集合所有值
由于對象的鍵值只能是字符串,不可以是對象類型,使用對象作為鍵值會(huì)被toString轉(zhuǎn)化為字符串"[object Object]",例如:
let obj1={key:1},obj2={key:2},obj={}; obj.value='objValue'; obj[obj1]='obj1Value'; //將對象obj1作為obj的鍵值 obj[obj2]='obj2Value'; console.log(obj);
輸出:Object { value: "objValue", "[object Object]": "obj2Value" },由于轉(zhuǎn)化為相同的鍵值字符串,obj2會(huì)覆蓋obj1
而使用map可以避免鍵值必須為字符串的限制,其鍵值可以為對象、數(shù)組等
let mymap=new Map([ ['stringKey','stringValue'], ['age',24], [obj1,'obj1Value'], [obj2,'obj2Value'], [['arr'],'arrValue'] ]);
打印mymap如下:
console.log(mymap.size);
mymap.set('key','value');//設(shè)置map的鍵、值 mymap.get('key');//通過鍵來取值 mymap.delete('key');//刪除對應(yīng)的鍵值 mymap.has('key');//判斷是否含有 //mymap.clear();//清除map中所有鍵值 //遍歷 mymap.forEach(function (value,key) { console.log(key+":"+value); })
mymap.set({},"obj1"); mymap.set({},"obj2");
以上語句obj2不會(huì)覆蓋obj1,由于空對象{}在內(nèi)存中不同的堆區(qū)申請存儲(chǔ)空間,所以作為鍵值它們是不同的
在用相同的字符串對對象屬性名或方法進(jìn)行命名時(shí)會(huì)發(fā)生命名沖突,而使用symbol產(chǎn)生的名字是不同的,例如:
let obj={}; obj[Symbol('name')]="小趙"; obj[Symbol('name')]="小錢"; console.log(obj);
結(jié)果如下,不會(huì)覆蓋第一句:
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。