es6語法

  es6又稱爲es2015,爲javascript的一個重要標準,至今並無被全部瀏覽器兼容javascript

<script>
        /**
         * let,用於解決javascript中無塊級做用域
         */
        {
            let a = "test";
        }
        //console.log(a); // Uncaught ReferenceError:  is not defined

        /**
         * const,也是塊級做用域,解決javascript中無常量
         */
        {
            const a = "test";
            //a = "123";  // Uncaught TypeError: Assignment to constant variable.
            const b = {name:"tom", age:18};
            b.age = 13;
            console.log(b); // {name: "tom", age: 13} 不能改變自己的值,但能夠改變其引用的值
        }

        /**
         * 箭頭函數,javascript中函數的語法糖, 簡化了函數的書寫
         */
        {
            let a = function (m, n) {
                return m+n;
            }
            console.log(a(1, 2));   // 3

            a = (m, n) => m+n;
            console.log(a(1, 2));   // 3
        }

        /**
         * 箭頭函數中this的指向
         */
        {
            let people = {
                walk: function () {
                    console.log(this);  // people
                },
                walkIn: function () {
                    setTimeout(function () {
                        console.log("walkIn");
                        console.log(this);   // window
                    }, 100);
                },
                walkInArrow: function () {
                    setTimeout(() => {
                        console.log("walkInArrow");
                        console.log(this);  // people
                    }, 200)
                },
                walkInArrow2: () => {
                    setTimeout(() => {
                        console.log("walkInArrow2");
                        console.log(this);  // window
                    }, 300)
                }
            }
            people.walk();
            people.walkIn();
            people.walkInArrow();
            people.walkInArrow2();
        }

        /**
         * 函數參數默認值
         */
        {
            let fun1 = function (value) {
                value = value || "defaultValue";
                console.log(value);
            }
            fun1(123);  // 123
            fun1(); // defaultValue

            fun1 = function (value="defaultValue") {
                console.log(value);
            }
            fun1(123);  // 123
            fun1(); // defaultValue
        }

        /**
         * 裝箱與拆箱
         */
        {
            let fun1 = function (...args) {
                for (let arg of args){
                    console.log(arg);
                }
            }
            fun1(1, 2, 3);  // 1 2 3

            fun1 = function (x, y, z) {
                return x+y+z;
            }
            console.log(fun1(...[1, 2, 3]));    // 6

            let arr1 = [1, 2, 3];
            let arr2 = [4, 5, 6];
            let arr3 = [...arr1, ...arr2];
            console.log(arr3);  // [1, 2, 3, 4, 5, 6]
        }

        /**
         * 解構賦值
         */
        {
            let [name, age, sex] = ["tom", 18, "male"];
            console.log("name="+name+", age="+age+", sex="+sex);   // name=tom, age=18, sex=male

            let {name: name2, age: age2, sex: sex2} = {name: "alice", age: 20, sex: "female"};
            console.log("name2="+name2+", age2="+age2+", sex2="+sex2);  // name=alice, age=20, sex=female
        }

        /**
         * 字符串拼接
         */
        {
            let name = 'tom';
            let sex = 'male';
            let age = 18;
            console.log(`name=${name}, sex=${sex}, age=${age}`);    // name=tom, sex=male, age=18
        }

        /**
         * 類
         */
        class Animal{
            constructor(name, age){
                this.name = name;
                this.age = age;
            }

            self_introduce(){
                console.log(`My name is ${this.name}, and I'm ${this.age} years old.`);
            }

            static getClassName(){
                return "Animal";
            }
        }

        {
            let animal = new Animal('tom', 18);
            animal.self_introduce();    // My name is tom, and I'm 18 years old.
            console.log(Animal.getClassName()); // Animal
        }

        class People extends Animal{
            constructor(name, age, language){
                super(name, age)
                this.language = language;
            }

            self_introduce(){
                super.self_introduce();
                console.log(`And I speak ${this.language}.`);
            }
        }

        {
            let people = new People("alice", 20, "chinese");
            people.self_introduce();    // My name is alice, and I'm 20 years old.
                                        // And I speak chinese.
        }
    </script>
相關文章
相關標籤/搜索