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>