Was sind die neuen Funktionen von es6?

藏色散人
Freigeben: 2023-01-06 16:26:42
Original
3721 Leute haben es durchsucht

Zu den neuen Funktionen von ES6 gehören: 1. let und const; 3. Template-String; 5. Objektaspekte, wie z. B. Map und Set; und Pfeile Funktion; 7. Klassenschlüsselwort; 8. Versprechen und Proxy 9. Modularisierung;

Was sind die neuen Funktionen von es6?

Die Betriebsumgebung dieses Tutorials: Windows 10-System, ECMAScript Version 6, Dell G3-Computer.

Was sind die neuen Funktionen von es6?

ES6 neue Funktionen

1, let und const

Wie bereits erwähnt: https://www.php.cn/js-tutorial-499866.html

2, Symbol

Symbol ist ein neuer grundlegender Datentyp, der in ES6 eingeführt wurde. Er wird zur Darstellung eines eindeutigen Werts verwendet und kann nicht mit anderen Datentypen verwendet werden. Es ist neben undefiniert, null, Zahl, Zeichenfolge, Boolean und Objekt der siebte Datentyp in JavaScript.

Sie können einen Symbolwert wie folgt erstellen:

const a = Symbol();
console.log(a);  //Symbol()

//因为Symbol是基本数据类型,而不是对象,不能 new 。
const a = new Symbol();//报错,Symbol is not a constructor
Nach dem Login kopieren

Nachdem Sie Symbol() verwendet haben, um einen Wert vom Typ Symbol zu erstellen und ihn einer Variablen zuzuweisen, erhalten Sie einen eindeutigen Wert im Speicher. Außer durch die Variable a kann niemand diesen Wert in irgendeinem Bereich neu erstellen Build-Vorlagen

Für ES6:
Verwenden Sie ${} zum Definieren; Was sind die neuen Funktionen von es6? Backticks (``), um es direkt zu tun;

const a = Symbol();const b = Symbol();
Nach dem Login kopieren

Sehr einfach zu verwenden

3.1 Neue String-Methode (ergänzend)

  • includes() Bestimmt, ob der String den Parameter string enthält und gibt einen booleschen Wert zurück.
  • startsWith() / endWith(), bestimmen Sie, ob die Zeichenfolge mit der Parameterzeichenfolge beginnt oder endet. Gibt einen booleschen Wert zurück. Diese beiden Methoden können einen zweiten Parameter haben, eine Zahl, die die Position angibt, an der die Suche gestartet werden soll.

  • <script>
          url="xxxxxx"
           // es6之前
           let html="<div>"+
                      " <a>"+url+"</a>"+
                   "</div>";
    		//es6
           let eshtml=`<div>
                       <a>${url}</a>
                   </div>`</script>
    Nach dem Login kopieren
    ${}来界定;
    反引号(``)直接搞定;
let str = &#39;blue,red,orange,white&#39;;str.includes(&#39;blue&#39;);
//truestr.startsWith(&#39;blue&#39;);
//true
str.endsWith(&#39;blue&#39;);
//false
Nach dem Login kopieren

非常好用

3.1 字符串新方法(补充)

  • includes()判断字符串是否包含参数字符串,返回boolean值。
  • startsWith() / endsWith(),判断字符串是否以参数字符串开头或结尾。返回boolean值。这两个方法可以有第二个参数,一个数字,表示开始查找的位置。
console.log(&#39;hello&#39;.repeat(2));   
//&#39;hellohello&#39;
Nach dem Login kopieren
  • repeat()方法按指定次数返回一个新的字符串。
let arr = &#39;hell&#39;;console.log(arr.padEnd(5,&#39;o&#39;));  
//&#39;hello&#39;console.log(arr.padEnd(6,&#39;o&#39;));  
//&#39;helloo&#39;console.log(arr.padEnd(6));  
//&#39;hell  &#39;,如果没有指定将用空格代替
console.log(arr.padStart(5,&#39;o&#39;));  
//&#39;ohell&#39;
Nach dem Login kopieren
  • padStart()/padEnd()
  • Die Methode repeat() gibt so oft eine neue Zeichenfolge zurück, wie angegeben.

let [a,b,c] = [1,2,3];console.log(a,b,c);    //1,2,3
 let [a,b,c] = [1,,3];console.log(a,b,c);    //1,undefined,3
 let [a,,b] = [1,2,3];console.log(a,b);//1,3
 let [a,..b] = [1,2,3];  
 //...是剩余运算符,表示赋值运算符右边除第一个值外剩余的都赋值给b
 console.log(a,b);
 //1,[2,3]
Nach dem Login kopieren
padStart()/padEnd(), verwenden Sie den Parameter string, um die Zeichenfolge entsprechend der angegebenen Länge von vorne oder hinten zu vervollständigen und eine neue Zeichenfolge zurückzugeben.

rrree 4. Destrukturierender Ausdruck
Destrukturierende Zuweisung ist eine Erweiterung des Zuweisungsoperators. Es handelt sich um einen Mustervergleich für ein Array oder ein Objekt und weist dann den darin enthaltenen Variablen Werte zu. String

sowie die neuen

Map und Set

von ES6 können alle Destrukturierungsausdrücke verwenden. 4.1 Array-Destrukturierung ähnlich wie bei Arrays , aber der Variablenname auf der linken Seite muss den Attributnamen des Objekts verwenden und geschweifte Klammern {} anstelle von eckigen Klammern []

let obj = { 
	name: "ren", 
	age: 12, 
	sex: "male" };let { name, age, sex } = obj;console.log(name, age, sex); 
	//&#39;ren&#39; 12 &#39;male&#39;let { name: myName, age: myAge, sex: mySex } = obj; 
	//自定义变量名console.log(myName, myAge, mySex); 
	//&#39;ren&#39; 12 &#39;male&#39;
Nach dem Login kopieren

5. Objektaspekt

5.1 Karte und Satz

Karte und Set wurden neu in es6 hinzugefügt. Objekt

5.1.1 Map

Map-Objekt wird zum Speichern von Schlüssel-Wert-Paaren verwendet. Jeder von JavaScript unterstützte Wert kann als Schlüssel (Schlüssel) oder Wert (Wert) verwendet werden.

Anders als bei Objekten können die Schlüssel von

Objekt nur
Strings

oder die
    Symbolwerte von ES6 sein, während Map ein beliebiger Wert sein kann.
  • Map-Objekt hat ein Größenattribut, das die Anzahl der Schlüssel-Wert-Paare speichert, während Objektobjekt kein ähnliches Attribut hat.

  • let myMap = new Map([[&#39;name&#39;,&#39;ren&#39;],[&#39;age&#39;,12]]);console.log(myMap);  
    //{&#39;name&#39;=>&#39;ren&#39;,&#39;age&#39;=>12}myMap.set(&#39;sex&#39;,&#39;male&#39;);console.log(myMap);  
    //{&#39;name&#39;=>&#39;ren&#39;,&#39;age&#39;=>12,&#39;sex&#39;=>&#39;male&#39;}console.log(myMap.size);  
    //3myMap.get(&#39;name&#39;);  //&#39;ren&#39;myMap.has(&#39;age&#39;); 
     //truemyMap.delete(&#39;age&#39;);  
     //truemyMap.has(&#39;age&#39;);  
     //falsemyMap.get(&#39;age&#39;);  
     //undefined
    Nach dem Login kopieren

    5.1.2 Set

  • kann als Set-Sammlungsobjekt des Backends verstanden werden
Das Set-Objekt ähnelt dem Map-Objekt, speichert jedoch keine Schlüssel-Wert-Paare. Ähnlich einem Array, aber jedes Element ist einzigartig.

let mySet = new Set([1,2,3]);
//里面要传一个数组,否则会报错console.log(mySet);  
//{1,2,3}mySet.add(4);console.log(mySet);  
//{1,2,3,4}mySet.delete(1);  
//truemySet.has(1);  
//falseconsole.log(mySet);  
//{2,3,4}
Nach dem Login kopieren
Mit der Einzigartigkeit

-Funktion des Set-Objekts können Sie ganz einfach

eine Duplizierung des Arrays erreichen

let arr = [1,1,2,3,4,4];let mySet = new Set(arr);
let newArr = Array.from(mySet);console.log(newArr);  
//[1,2,3,4]
Nach dem Login kopieren

5.3 数组的新方法

  • 新增的方法有:
  1. Array.from()是内置对象Array的方法,实例数组不能调用
  2. includes() 参数:数值 -------- 返回值:true/false
  3. map()filter() 参数:函数-------- 返回值:数组
  4. forEach() 参数:函数-------- 返回值:undefined
  5. find() 参数:函数-------- 返回值:数值
  6. some()every() 参数:函数-------- 返回值:true/false

5.3.1 Array.from()方法

Array.from()方法可以将可迭代对象转换为新的数组。

  • 函数可接受3个参数(后两个参数可以没有):
    • 第一个表示将被转换的可迭代对象(如果只有一个参数就是把形参转变成数组)
    • 第二个是回调函数,将对每个数组元素应用该回调函数,然后返回新的值到新数组,
    • 第三个是回调函数内this的指向。
let arr = [1, 2, 3];let obj = {
    double(n) {
        return n * 2;
    }}console.log(Array.from(arr, function (n){
    return this.double(n);}, obj)); // [2, 4, 6]
Nach dem Login kopieren

5.3.2 includes()方法

参数:数值 -------- 返回值:true/false
includes()方法------是查看数组中是否存在这个元素,存在就返回true,不存在就返回false

let arr = [1,33,44,22,6,9]let ary = arr.includes(22)console.log(ary)
Nach dem Login kopieren

5.3.3 map()、filter() 方法

参数:函数-------- 返回值:数组
map()方法-----要利用原数组经过运算后的数组,或者从对象数组中拿某个属性
filter()方法------是将符合挑选的筛选出来成为一个新数组,新数组不会影响旧数组。

<script>
	let arr = [1, 33, 44, 2, 6, 9];

	let newarr1 = arr.filter((v) => v > 10); //newarr1-------[33, 44]
	let newarr2 = arr.filter((v) => v * 2);  //newarr2-------[1, 33, 44, 2, 6, 9]

	let newarr3 = arr.map((v) => v > 10);    //newarr3-------[false, true, true, false, false, false]
	let newarr4 = arr.map((v) => v * 2);     //newarr4-------  [2, 66, 88, 4, 12, 18]</script>
Nach dem Login kopieren

5.3.4 forEach()方法

参数:函数-------- 返回值:undefined

forEach() 方法------是循环遍历数组中的每一项,没有返回值

find()方法---------是查找数组中符合条件的第一个元素,直接将这个元素返回出来

let arr = [1,33,44,2,6,9]let a1= []arr.forEach((v, i)=>{
  if (v > 10) {
    a1.push(arr[i])
  }  })console.log(a1) [33,44]let a2= arr.find(v => v > 10)console.log(a2)
Nach dem Login kopieren

5.3.4 find()方法

参数:函数-------- 返回值:数值

find()方法----------是查找数组中符合条件的第一个元素,直接将这个元素返回出来

let arr = [1,33,44,2,6,9]let a= arr.find(v => v > 10)console.log(a) // 33
Nach dem Login kopieren

5.3.6 some()、every() 方法

参数:函数-------- 返回值:true/false

some()方法------找到一个符合条件的就返回true,所有都不符合返回false
every()方法------数组所有值都符合条件才会返回true,有一个不符合返回false

let arr = [1,2,3,4,6,11]let newarr = arr.some(function(v){
  return v > 10})console.log(newarr) 
  //truelet newarr2 = arr.every(function(v){
  return v > 10})console.log(newarr2) 
  //false
Nach dem Login kopieren

5.4 object的新方法

在 ES6 中,添加了Object.is()Object.assign()Object.keys()Object.values()Object.entries()等方法。

5.4.1 Object.is()

  • Object.is()方法用来判断两个值是否为同一个值,返回一个布尔类型的值。
const obj1 = {};const obj2 = {};console.log(Object.is(obj1, obj2)); // falseconst obj3 = {};const value1 = obj3;const value2 = obj4;console.log(Object.is(value1, value2)); // true
Nach dem Login kopieren

5.4.2 Object.assign()

  • Object.assign()方法用于将所有可枚举属性的值从一个或多个源对象分配到目标对象,并返回目标对象。------难理解看实例
    对象合并
const obj1 = { a: 1 };const obj2 = { b: 2 };const obj3 = { a:5 , c: 3 };//对象合并,把后面对像合并到第一个对象,对象里相同的属性会覆盖Object.assign(obj1, obj2, obj3);console.log(obj1); // { a: 5, b: 2 , c:3}
Nach dem Login kopieren

5.4.3 Object.keys()、Object.values()、Object.entries()

  • Object.keys() 返回对象所有属性
  • Object.values() 返回对象所有属性值
  • Object.entries() 返回多个数组,每个数组是 key–value
    不解释直接看例子
<script>
	let person = {
		name: "admin",
		age: 12,
		language: ["java", "js", "css"],
	};
	console.log(Object.keys(person)); //[ &#39;name&#39;, &#39;age&#39;, &#39;language&#39; ]
	
	console.log(Object.values(person)); //[ &#39;admin&#39;, 12, [ &#39;java&#39;, &#39;js&#39;, &#39;css&#39; ] ]
	
	console.log(Object.entries(person));    /* [
	                                                     ["name", "admin"],
	                                                     ["age", 12],
	                                                     ["language", ["java", "js", "css"]],
	                                                 ]; */</script>
Nach dem Login kopieren

5.5 对象声明简写

<script>
			
      let name =&#39;admin&#39;
      let age = 20
      //es6之前
      // let person={
      //     name:name,
      //     age:age
      // }

      //es6  声明对象时的属性名与引用的变量名相同就可以省略
      let person={
          name,
          age      }</script>
Nach dem Login kopieren

5.6 …(对象扩展符)

  1. 拷贝
<script>
	let person={
		name: "admin",
		age: 12,
		wife:"迪丽热巴"
	}
	
	let person2={...person}
	
	console.log(person2===person);//false
	console.log(person2);
	//{name: &#39;admin&#39;, age: 12, wife: "迪丽热巴"}
	</script>
Nach dem Login kopieren
  1. 合并对象
<script>
	const obj1 = { a: 1 };
	const obj2 = { b: 2 };
	const obj3 = { a: 5, c: 3 };
	
    let newObj ={...obj1,...obj2,...obj3}
	console.log(newObj); 
	// { a: 5, b: 2 , c:3}
	</script>
Nach dem Login kopieren

6、函数方面

6.1 参数默认值

<script>

	// es6之前
	// function add(a, b) {
	//     if(!a) a=0
	//     if(!b) b=0
	// 	return a + b;
	// }
	
	//es6
	function add(a = 0, b = 0) {
		return a + b;
	}
	let x=add(); 
	let y=add(2); 
	let z=add(3, 4); 
          console.log(x,y,z); //x=0, y=2, z=7</script>
Nach dem Login kopieren

6.2 箭头函数

箭头函数实现了一种更加简洁的书写方式。箭头函数内部没有arguments,也没有prototype属性,所以不能用new关键字调用箭头函数。

let add = (a,b) => {
    return a+b;}let print = () => {
    console.log(&#39;hi&#39;);}let fn = a => a * a;
    //当只有一个参数时,括号可以省略,函数体只有单行return语句时,大括号也可以省略。
Nach dem Login kopieren

6.3 箭头函数和普通函数最大的区别在于其内部this永远指向其父级对象的this。(重点)

 var age = 123;
 let obj = {
     age:456,
     say:() => {
         console.log(this.age);  //this指向window
     }
 };obj.say();   //123
Nach dem Login kopieren

7、class(类)

class 作为对象的模板被引入ES6,你可以通过 class 关键字定义类。class 的本质依然是一个函数。

  1. 创建类
<script>
	class person {
		//关键字声明方式
		constructor(name) {
                  this.name=name              }           
		say() {
			console.log("hello");
		}
	}

	var p = new person(&#39;p&#39;);
	p.say(); //&#39;hello&#39;
	console.log(p.name);</script>
Nach dem Login kopieren
  1. 类的继承
    类的继承通过extends关键字实现。
    子类必须在constructor中调用super()
<script>
	class Person {
		constructor(name, age) {
			this.name = name;
			this.age = age;
		}
		say() {
			console.log(this.name + ":" + this.age);
		}
	}
	class Student extends Person {
		constructor(name, age, sex) {
			super(name, age);
			this.sex = sex;
		}
	}
	var student = new Student("admin", 12, "male");
	student.name;   //&#39;admin&#39;
	student.sex;    //&#39;male&#39;
	student.say(); //&#39;ren:12&#39;</script>
Nach dem Login kopieren

8、promise和proxy

讲不清楚,等我学会了,后面在讲

9、模块化

  1. 导入

ES6使用关键字 import 导入模块(文件),有两种常用的方式:

import ‘模块名称’  from  ‘路径’;import  ‘路径’;
Nach dem Login kopieren
  1. 导出

ES6 通过 export 和export default 导出模块。

let name = &#39;ren&#39;,age = 12;export {name,age};
//注意:变量需要用大括号包裹,然后才能向外输出
Nach dem Login kopieren

模块化优点

  1.防止命名冲突
Nach dem Login kopieren
  2.复用性强
Nach dem Login kopieren

10、运算符

... 扩展运算符
可选链 ?.
函数绑定运算符::


若本文对你有帮助 点个赞 点个关注


总结——ES6思维导图

Was sind die neuen Funktionen von es6?

推荐学习:《react视频教程

Das obige ist der detaillierte Inhalt vonWas sind die neuen Funktionen von es6?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
es6
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage