JavaWeb,ES6的学习

概述

ECMAScript 6,简称ES6,是JavaScript语言的一次重大更新。它于2015年发布,是原来的ECMAScript标准的第六个版本。ES6带来了大量的新特性,包括箭头函数、模板字符串、let和const关键字、解构、默认参数值、模块系统等等,大大提升了JavaScript的开发体验。

let和const

let

1、let 不能重复声明

2、let有块级作用域,非函数的花括号(即{ }括号)遇见let会有块级作用域,也就是只能在花括号里面访问

3、let不会预解析进行变量提升(要访问必须要在声明let变量代码后)

4、let 定义的全局变量不会作为window的属性

5、let在es6中推荐优先使用

const

1、新增const和let类似,只是const定义的变量不能修改,即const为不可更改的let

2、并不是变量的值不得改动,而是变量指向的那个内存地址所保存的数据不得改动。

3、const用来定义不可更改的常量

模板字符串

模板字符串(template string)是增强版的字符串,用反引号(`)标识

1、字符串中可以出现换行符

2、模板字符串内输出变量和拼接变量使用 ${xxx} 形式

例:

let num = 8let str = `aaaa${num}abbbccc`
console.log(str)

控制台的输出结果为

aaa

a8a

bbb

ccc

解构表达式

解构赋值是一种方便的语法,可以快速将数组或对象中的值拆分并赋值给变量。解构赋值的语法使用花括号 {} 表示对象方括号 [] 表示数组

通过数组解构将数组中的值赋值给变量

let [a, b, c] = [1, 2, 3]; //新增变量名任意合法即可,本质是按照顺序进行初始化变量的值
console.log(a); // 1
console.log(b); // 2
console.log(c); // 3

数组 [1, 2, 3] 中的第一个值赋值给 a 变量,第二个值赋值给 b 变量,第三个值赋值给 c 变量。 可以使用默认值为变量提供备选值,在数组中缺失对应位置的值时使用该默认值。例如:

let [a, b, c, d = 4] = [1, 2, 3];
console.log(d); // 4

对象解构赋值给变量

可以通过对象解构将对象中的值赋值给变量:

let {a, b} = {a: 1, b: 2};
//新增变量名必须和属性名相同,本质是初始化变量的值为对象中同名属性的值
//等价于 let a = 对象.a  let b = 对象.bconsole.log(a); // 1
console.log(b); // 2
  • 该语句将对象 {a: 1, b: 2} 中的 a 属性值赋值给 a 变量,b 属性值赋值给 b 变量。 可以为标识符分配不同的变量名称,使用 : 操作符指定新的变量名。例如:
let {a: x, b: y} = {a: 1, b: 2};
console.log(x); // 1
console.log(y); // 2

函数参数解构赋值

解构赋值也可以用于函数参数:

function add([x, y]) {return x + y;
}
add([1, 2]); // 3
  • 该函数接受一个数组作为参数,将其中的第一个值赋给 x,第二个值赋给 y,然后返回它们的和。
  • ES6 解构赋值让变量的初始化更加简单和便捷。通过解构赋值,我们可以访问到对象中的属性,并将其赋值给对应的变量,从而提高代码的可读性和可维护性。

箭头函数

箭头函数类似于Java中的Lambda表达式

普通的函数声明:

let fun1 = function(){} //普通的函数声明

箭头函数声明的格式:

let fun2 = ()=>{} //箭头函数声明 lambda表达式
let fun3 = (x)=>{return x+1}

参数列表中有且仅有一个参数,()括号可以省略不写:

let fun4 = x=>{return x+1}

如果函数体中只有一行代码,{}可以省略不写:

let fun5 = x=>console.log(x)

如果函数体中只有一行代码而且只有一个return语句,{}和return都可以不写

let fun6 = x=>x+1

在箭头函数中,调用this时,this指的不是本函数的调用者,而是更外层的this

rest和spread

rest参数,在形参上使用 和JAVA中的可变参数几乎一样,格式为…args

<script>// 1 参数列表中多个普通参数  普通函数和箭头函数中都支持let fun1 = function (a,b,c,d=10){console.log(a,b,c,d)}let fun2 = (a,b,c,d=10) =>{console.log(a,b,c,d)}fun1(1,2,3)fun2(1,2,3,4)// 2 ...作为参数列表,称之为rest参数 普通函数和箭头函数中都支持 ,因为箭头函数中无法使用arguments,rest是一种解决方案let fun3 = function (...args){console.log(args)}let fun4 = (...args) =>{console.log(args)}fun3(1,2,3)fun4(1,2,3,4)// rest参数在一个参数列表中的最后一个只,这也就无形之中要求一个参数列表中只能有一个rest参数//let fun5 =  (...args,...args2) =>{} // 这里报错
</script>

spread参数,在实参上使用rest,格式为…数组名…对象名

<script>let arr =[1,2,3]//let arrSpread = ...arr;// 这样不可以,...arr必须在调用方法时作为实参使用let fun1 =(a,b,c) =>{console.log(a,b,c)}// 调用方法时,对arr进行转换 转换为1,2,3fun1(...arr)//应用场景1 合并数组let arr2=[4,5,6]let arr3=[...arr,...arr2]console.log(arr3)//应用场景2 合并对象属性let p1={name:"张三"}let p2={age:10}let p3={gender:"boy"}let person ={...p1,...p2,...p3}console.log(person)</script>

  1. rest作为参数列表只能有一个,且只能在参数列表的最后一个
  2. spread相当于将数组或对象其中的每个元素或属性一一罗列,且用逗号隔开,但是只能用于实参处

对象创建的语法糖

ES6中新增了对象创建的语法糖,支持了class extends constructor等关键字,让ES6的语法和面向对象的语法更加接近

具体的知识点见代码,例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script>class Person{//属性,这些属性的类型省略,默认为let,属性前加上#就相当于加private,加上#后,在类中调用时也要加上#name //名字#age //年龄//getter和setter函数get getname(){return this.name}set setname(name){this.name=name}get getage(){return this.age}set setage(age){this.age = age}//Person类中的函数,也不需要声明函数返回值,静态函数在其函数名前加上static即可eat(food){console.log(food)}static sleep(){console.log("sleep")}//构造器,用constructor表示constructor(name,age){this.name=namethis.#age=age}}</script>
</head>
<body></body>
</html>

  1. 属性的类型省略,默认为let
  2. 属性前加上#就相当于加private,加上#后,在类中调用时也要加上#
  3. Person类中的函数,也不需要声明函数返回值,静态函数在其函数名前加上static即可
  4. 调用构造函数时,使用 new 类名(参数) 即可

对象的深拷贝和浅拷贝

对象的拷贝是快速获得和已有对象相同的对象的方式

  • 浅拷贝
<script>let arr  =['java','c','python']let person ={name:'张三',language:arr}// 浅拷贝,person2和person指向相同的内存let person2 = person;person2.name="小黑"console.log(person.name)
</script>
  • 深拷贝
<script>let arr  =['java','c','python']let person ={name:'张三',language:arr}// 深拷贝,通过JSON和字符串的转换形成一个新的对象let person2 = JSON.parse(JSON.stringify(person))person2.name="小黑"console.log(person.name)console.log(person2.name)
</script>

模块化处理

概述

模块化是一种组织和管理前端代码的方式,将代码拆分成小的模块单元,使得代码更易于维护、扩展和复用。它包括了定义、导出、导入以及管理模块的方法和规范。

优势

  1. 提高代码可维护性:通过将代码拆分为小的模块单元,使得代码结构更为清晰,可读性更高,便于开发者阅读和维护。
  2. 提高代码可复用性:通过将重复使用的代码变成可复用的模块,减少代码重复率,降低开发成本。
  3. 提高代码可扩展性:通过模块化来实现代码的松耦合,便于更改和替换模块,从而方便地扩展功能。

ES6的几种暴露和导入方式

  1. 分别导出,分别导入
  2. 统一导出,统一导入
  3. 默认导出,默认导入

分别导出

向外暴露成员在相应的变量、函数、类前加上export即可,例:

//1.分别暴露
// 模块想对外导出,添加export关键字即可!
// 导出一个变量
export const PI = 3.14
// 导出一个函数
export function sum(a, b) {return a + b;
}
// 导出一个类
export class Person {constructor(name, age) {this.name = name;this.age = age;}sayHello() {console.log(`Hello, my name is ${this.name}, I'm ${this.age} years old.`);}
}

分别导入

  • {}中导入要使用的来自于module.js中的成员
  • {}中导入的名称要和module.js中导出的一致,也可以在此处起别名,使用as关键字,{}中如果定义了别名,那么在当前模块中就只能使用别名
  • {}中导入成员的顺序可以不是暴露的顺序
  • 一个模块中可以同时有多个import,多个import可以导入多个不同的模块,也可以是同一个模块
//import {PI ,Person ,sum }  from './module.js'
//import {PI as pi,Person as People,sum as add}  from './module.js'
import {PI ,Person ,sum,PI as pi,Person as People,sum as add}  from './module.js'
// 使用暴露的属性
console.log(PI)
console.log(pi)
// 调用暴露的方法
let result1 =sum(10,20)
console.log(result1)
let result2 =add(10,20)
console.log(result2)
// 使用暴露的Person类
let person1 =new Person('张三',10)
person1.sayHello()
let person2 =new People('李四',11)
person2.sayHello()

统一导出

使用export{成员名,成员名,……}的方式就可以将{}中的对象统一导出

// 定义一个常量
const PI = 3.14
// 定义一个函数
function sum(a, b) {return a + b;
}
// 定义一个类
class Person {constructor(name, age) {this.name = name;this.age = age;}sayHello() {console.log(`Hello, my name is ${this.name}, I'm ${this.age} years old.`);}
}
// 统一对外导出(暴露)
export {PI,sum,Person
}

统一导入

导入其他文件的成员使用import关键字即可,如下代码所示,*代表所有成员,as后面的m1是对象名,是一个封装了./module.js中的所有暴露成员的对象

/**代表module.js中的所有成员m1代表所有成员所属的对象
*/
import * as m1 from './module.js'
// 使用暴露的属性
console.log(m1.PI)
// 调用暴露的方法
let result =m1.sum(10,20)
console.log(result)
// 使用暴露的Person类
let person =new m1.Person('张三',10)
person.sayHello()

默认导出

默认导出会在暴露成员中增加一个名为default的成员

// 默认导出
export default sum

默认导入

import {default as add} from './module.js' // 用的少

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/654178.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

随便封装一下BaseActivity 之 二

接着上回&#xff0c;菊花也稍微封装一下 老规矩&#xff0c;上码 一、定义一个菊花interface&#xff0c;真正实现菊花的接口类 open interface ILoading {/*** 获取加载服务*/fun getLoad(): Any?/*** 注册目标view*/fun register(target: Any)/*** 注册目标view*/fun re…

天拓四方:物联网网关在机械制造企业的应用

随着物联网技术的不断发展&#xff0c;越来越多的机械制造企业开始探索如何利用物联网技术提升生产效率、降低运营成本。物联网网关作为物联网架构中的关键设备&#xff0c;能够实现设备间的数据交互与远程控制&#xff0c;为机械制造企业带来了巨大的商业价值。它能够实现设备…

负载均衡是什么,负载均衡有什么作用

一、什么是负载均衡 负载均衡是一种在计算机网络和系统架构中使用的技术&#xff0c;用于均衡分发工作负载到多个资源&#xff0c;比如&#xff1a;服务器、计算节点或存储设备上&#xff0c;以提高系统的性能、可伸缩性。 在传统的单个服务器架构中&#xff0c;当请求量增加…

leetcode-反转链表

206. 反转链表 题解&#xff1a; 定义两个指针prev和cur,分别指向当前节点的前一个节点和当前节点&#xff0c;初始时&#xff0c;prev为None&#xff0c;cur为head&#xff0c;在遍历的过程中&#xff0c;我们需要创建一个临时指针用来指向cur.next&#xff0c;因为cur指向p…

漏洞原理XSS存贮型漏洞

漏洞原理XSS存贮型漏洞 XSS&#xff08;跨站脚本攻击&#xff09;是一种常见的Web安全漏洞&#xff0c;它允许攻击者将恶意代码注入到网页中&#xff0c;进而攻击用户的浏览器。存储型XSS漏洞是一种特定类型的XSS漏洞&#xff0c;它发生在Web应用程序中&#xff0c;其中用户输入…

小红叒战小紫

概率dp #include <iostream> #include <string> #include <stack> #include <vector> #include <queue> #include <deque> #include <set> #include <map> #include <unordered_map> #include <unordered_set> #…

在租户内启用SharePoint Embedded

要开启 SharePoint Embedded&#xff0c;你得是管理员&#xff0c;然后按照这些步骤操作&#xff1a; 登录到你的 SharePoint 管理中心。在左边的菜单里找到“设置”选项&#xff0c;点进去。 3. 在设置页面里找到“SharePoint Embedded 应用”。 4.如果这个功能还没开启&…

Android Settings 显示电池点亮百分比

如题&#xff0c;Android 原生 Settings 里有个 电池电量百分比 的选项&#xff0c;打开后电池电量百分比会显示在状态栏。 基于 Android 13 &#xff0c; 代码在 ./packages/apps/Settings/src/com/android/settings/display/BatteryPercentagePreferenceController.java &am…

【flutter项目类型】project type如何区分

通过项目中.metadata内容区分 如 # Used by Flutter tool to assess capabilities and perform upgrades etc. # # This file should be version controlled and should not be manually edited.version:revision: 85684f9300908116a78138ea4c6036c35c9a1236channel: stablep…

【大数据】Flink 架构(二):数据传输

《Flink 架构》系列&#xff08;已完结&#xff09;&#xff0c;共包含以下 6 篇文章&#xff1a; Flink 架构&#xff08;一&#xff09;&#xff1a;系统架构Flink 架构&#xff08;二&#xff09;&#xff1a;数据传输Flink 架构&#xff08;三&#xff09;&#xff1a;事件…

(Aliexpress)速卖通卖家通过自养号补单提高出单率

在跨境电商领域&#xff0c;有些卖家可能会遇到这样的问题&#xff1a;自己的速卖通店铺始终没有订单产生。那么&#xff0c;当速卖通店铺一直不出单时&#xff0c;我们应该如何进行补救呢&#xff1f;今天珑哥将围绕这个问题展开探讨&#xff0c;并分享一些提升速卖通店铺销量…

HCIP复习课(mpls实验)

1、IP配置&#xff1a; R1&#xff1a; R2&#xff1a; R3&#xff1a; R4&#xff1a; R5&#xff1a; R6&#xff1a; R7&#xff1a; R8&#xff1a; 2、rip&#xff0c;ospf配置&#xff1a; R2&#xff1a; R3&#xff1a; R4&#xff1a; R5&#xff1a; R6&#xff1a…

信创联盟--朗思科技加入证券基金行业信息技术应用创新联盟,共促金融信创发展

近期&#xff0c;证券基金行业信息技术应用创新联盟&#xff08;以下简称&#xff1a;信创联盟&#xff09;新一批成员单位名单公布&#xff0c;朗思科技LanSive凭借产品创新以及实践案例成功入选&#xff0c;正式成为信创联盟成员单位。 信创联盟由上交所联合行业券商倡议发起…

Threejs 展示——fbx 格式模型导入

文章目录 需求分析 需求 导入fbx 格式的模型数据 分析 需要准备 fbx 格式的数据&#xff0c;如下所示 <template><div id"three-canvas" /> </template> <script> // import { Color, MOUSE, PerspectiveCamera, Scene, WebGLRenderer } …

【LLVM Pass解读】Reassociate 重结合优化

run函数的分析 首先&#xff0c;ReassociatePass是一个FunctionAnalysis&#xff0c;所以其入口函数为 PreservedAnalyses ReassociatePass::run(Function &F, FunctionAnalysisManager &) { 首先对一个函数的基本块构造ReversePostOrderTraversal&#xff0c;该顺序…

canvas自定义扩展示例,新增属性和方法

查看专栏目录 canvas实例应用100专栏&#xff0c;提供canvas的基础知识&#xff0c;高级动画&#xff0c;相关应用扩展等信息。canvas作为html的一部分&#xff0c;是图像图标地图可视化的一个重要的基础&#xff0c;学好了canvas&#xff0c;在其他的一些应用上将会起到非常重…

少儿编程 2023年12月电子学会图形化编程等级考试Scratch一级真题解析(判断题)

2023年12月scratch编程等级考试一级真题 判断题(共10题,每题2分,共20分) 26、角色和造型的名称可以更改,但背景的名称不能更改 答案:错 考点分析:角色造型名称和背景名称都可以更改,所以错误 27、点击绿旗后,无论是否按下空格键,声音“Xylo1”都会完整播放完毕,“…

网诺安全文件上传总结

一、文件上传简介 文件上传漏洞是指用户上传了一个可执行的脚本文件&#xff08;木马、病毒、恶意脚本、webshell等&#xff09;&#xff0c;并通过此脚本文件获得了执行服务器端命令的能力。上传点一般出现在头像、导入数据、上传压缩包等地方&#xff0c;由于程序对用户上传…

自然语言处理中的词云生成

一.词云的介绍 自然语言处理中的词云技术是文本可视化的一种形式&#xff0c;用于展示文本数据中词语的频率分布。以下是词云在自然语言处理中的基本介绍和发展&#xff1a; 起源和发展&#xff1a; 词云的概念最初来源于信息可视化领域&#xff0c;用于将文本中的关键词以视…

邦芒支招:回避同事打探薪资的三大妙招

​​职场是人际关系特别复杂的地方&#xff0c;想要尽快的在众人当中脱颖而出&#xff0c;除了要有过硬的能力&#xff0c;还要懂得与人相处的技巧。这样才可以尽快的被老板看中&#xff0c;成为老板的心腹。获得自己想要的职位和薪资。 ​ ​一、可以反问对方 如果是好朋友向…