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

資訊專欄INFORMATION COLUMN

es6 知識總結(jié)--3

Keagan / 969人閱讀

es6知識總結(jié)--3

上午發(fā)表了一個總結(jié)覺得還是把自己的了解做成一個小系列吧,明天把那個總結(jié)一下!

es6對咱們es3,es5的數(shù)據(jù)類型進(jìn)行了升級下邊說新APIs!
js數(shù)據(jù)類型有Number、String 、oject、Boolean、Null、Undefined六種數(shù)據(jù)類型 !

下邊介紹 Math、Number、String 、Array、Boject的新 APIs

Math

Number

String

Array

Boject

Math

下邊我們介紹三個覺得大家能用的著的屬性Math.trunc()、Math.sqrt()、Math.sign()

let a=Math.trunc(4.1);                        //trunc去除整數(shù)的小數(shù)點部分
    console.log(a)//4
let b=Math.sign(-4);    //sign方法用于判斷一個數(shù)為正、負(fù)、0
let c=Math.sign(4.1);
let d=Math.sign(0);
    console.log(b);//-1
    console.log(c);//1
    console.log(d);//0
let e=Math.sqrt(4)      //sqrt 用于開一個數(shù)的平方根
    console.log(e)//2
let f=Math.cbrt(27);
    console.log(f);    //3*/
Number
console.log(Number.isInteger(12));   //true  //isInteger判斷數(shù)組是否為整數(shù) 
console.log(Number.isInteger(12.3)); //flase
console.log(Number.isNaN(12145))  //false   //isNaN用于檢查數(shù)組是否為NaN
console.log(Number.isNaN(NaN)) // true
String
var str="javascript";
console.log(str.includes("java"));//true   //includes()用來檢查字符串是否有該連接字符
console.log(str.includes("javt"));//false
console.log(str.startsWith("ja"));//true   //startsWith用來檢查字符串以什么開頭
console.log(str.endsWith("pt"));//true   //endsWith以什么結(jié)尾
console.log("1".repeat(20))//20 個 1     //repeat用來復(fù)制字符串
Array
let arr=[1,2,3,4,5];
let arr1=Array.from(arr);     //Array.from() 用來拷貝一份  
arr1=[2,2,3,4,55];
console.log(arr)
console.log(arr1);//[2,2,3,4,55]

console.log(Array.of(1,2,3))  //Array.of用于創(chuàng)建一個數(shù)組
let shuzu=[1,2,3,4,5,6]
console.log(shuzu.fill(4,1))  //fill傳兩個值后邊那個規(guī)定從一位開始全部替換*/
object
let obj={x:1,y:1}; 
let obj1={};  
Object.assign(obj1,obj)         //Object.assign
obj1.x=2;                       /*1.合并多個對象;2.克隆對象;3.為數(shù)組添加多個方法*/
console.log(obj1)
let obj2={a:2,b:"c"};           
//let obj1= Object.assign({},obj2,obj);
// console.log(obj1)//Object {a: 2, b: "c", x: 1, y: 1}
let obj3={aa:1,bb:2}
Object.assign(obj3,{
    sayhello:()=>{},
    sayhi:()=>{}
})
let person={
    name:"huahua",
    sex:"nan",
    age:18
}
let tao={
   // __proto__:person,
    xh:123
}
// console.log(tao)
Object.setPrototypeOf(tao,person)    //setPrototypeOf用于設(shè)置繼承屬性
console.log(tao.name)

同樣es6新規(guī)定了一個==Symbol==新屬性

ES5對象屬性名都是字符串容易造成屬性名的沖突。

var a = { name: "lucy"};

a.name = "lili";
這樣就會重寫屬性

說的明白點其實Symbol就是為了處理這件事情,它表示獨一無二的值
Symbol值不能與其他類型的值進(jìn)行運算

// 沒有參數(shù)的情況
        var s1 = Symbol();
        var s2 = Symbol();

        console.log(s1 === s2) // false

        // 有參數(shù)的情況
        var s1 = Symbol("foo");
        var s2 = Symbol("foo");

        console.log(s1 === s2) // false

Symbol值作為對象屬性名時,不能用點運算符

        var mySymbol = Symbol();

        // 第一種寫法
        var a = {};
        a[mySymbol] = "Hello!";

        // 第二種寫法
        var a = {
        [mySymbol]: "Hello!"
        };

        // 第三種寫法
        var a = {};
        Object.defineProperty(a, mySymbol, { value: "Hello!" });
         // 以上寫法都得到同樣結(jié)果
        console.log(a[mySymbol]) // "Hello!"

防止對象的屬性被串改

let chenxu={
            name:"chenxu",
            age:"17"
        }
        chenxu.name="晨旭"
        console.log(chenxu);//被修改*/
        let chenxu1={
            [Symbol("name")]:"chenxu",
            age:"17"
        }
        chenxu1[Symbol("name")]="晨旭";
        console.log(chenxu1.name);//undefind
        console.log(chenxu1)  //Object {age: "17", Symbol(name): "chenxu", Symbol(name): "晨旭"}

但是這里的Symbol在類外部也是可以訪問的,只是不會出現(xiàn)在for...in、for...of循環(huán)中,也不會被Object.keys()、Object.getOwnPropertyNames()返回。但有一個Object.getOwnPropertySymbols方法,可以獲取指定對象的所有Symbol屬性名!

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

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

相關(guān)文章

  • es6知識總結(jié)(一)

    摘要:知識點總結(jié)一,,能重復(fù)聲明,有前置功能。淺拷貝一個數(shù)組設(shè)置原型。永遠(yuǎn)是唯一的,不可能和別的重復(fù),可以阻止對象的屬性被篡改前面不能使用操作符。和的區(qū)別鍵名可以是任何數(shù)據(jù)類型初始化的時候必須一次性指定鍵名和鍵值。 es6知識點總結(jié)(一) let,var,const var:能重復(fù)聲明,有前置功能。 let:有塊級作用域,沒有前置功能,不能重復(fù)聲明。 const:有塊級作用域,用來聲明常量(...

    HelKyle 評論0 收藏0
  • ES6-7

    摘要:的翻譯文檔由的維護(hù)很多人說,阮老師已經(jīng)有一本關(guān)于的書了入門,覺得看看這本書就足夠了。前端的異步解決方案之和異步編程模式在前端開發(fā)過程中,顯得越來越重要。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。 JavaScript Promise 迷你書(中文版) 超詳細(xì)介紹promise的gitbook,看完再不會promise...... 本書的目的是以目前還在制定中的ECMASc...

    mudiyouyou 評論0 收藏0
  • es6 知識總結(jié)--4

    摘要:函數(shù)中使用關(guān)鍵詞定義構(gòu)造函數(shù)的的方法和屬性上面代碼首先用定義了一個類,可以看到里面有一個方法,這就是構(gòu)造方法,而關(guān)鍵字則代表實例對象。這是因為子類沒有自己的對象,而是繼承父類的對象,然后對其進(jìn)行加工。 ES6 classes(類) 我們在編程過程中常常用到面向?qū)ο螅瑢ο髣?chuàng)建實例這個方法,但是es6中給我封裝了一個class類下邊給大家介紹一下! Ecmascript5方法 //萬事萬物...

    MkkHou 評論0 收藏0
  • 新手開發(fā)中常用ES6基礎(chǔ)知識總結(jié)

    摘要:感覺對我這種沒實習(xí)沒工作的新手,雖然一些高級的功能暫時用不上,但是一些基礎(chǔ)的知識還是為平時的開發(fā)提供了巨大的便利。學(xué)習(xí)告一段落,現(xiàn)在結(jié)合平時的開發(fā),總結(jié)一些常用的知識。日常開發(fā)中,塊級作用域中使用的變量,盡量使用或者聲明。使用時,進(jìn)行合并。 很早之前就學(xué)過TypeScript和ES6,后來做項目的時候零零散散用了些。這幾天又系統(tǒng)地把ES6的知識看了一遍。感覺對我這種沒實習(xí)沒工作的新手,...

    Paul_King 評論0 收藏0
  • ES6 常用知識總結(jié)

    摘要:常用知識總結(jié)之前總結(jié)了中的一些知識點。在年正式發(fā)布了,簡稱,又稱為。作為構(gòu)造函數(shù)的語法糖,同時有屬性和屬性,因此同時存在兩條繼承鏈。子類的屬性,表示構(gòu)造函數(shù)的繼承,總是指向父類。 ES6常用知識總結(jié) 之前總結(jié)了es5中js的一些知識點。這段時間看了石川blue老師講解的es6課程,結(jié)合阮一峰老師的es6教程,隨手做了一些筆記和總結(jié)分享給大家。內(nèi)容還是es6主要的知識點,基本沒有什么創(chuàng)新...

    leap_frog 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<