面试前端实习常问的关于【ES6新特性】的问题

news2024/9/23 19:27:00

ES6新特性

日常前端代码开发中,有哪些值得用 ES6 去改进的编程优化或者规范?

  1. 常用箭头函数来取代有this指向的函数
  2. 常用 let 取代 var 命令
  3. 常用数组/对象的结构赋值来命名变量(结构更清晰,语义更明确,可读性更好)
  4. 在长字符串多变量组合场合,用模板字符串来取代字符串
  5. 用 class 类取代传统的构造函数,来生成实例化对象。
  6. 在大型应用开发中,要保持 module 模块化开发思维,分清模块之间的关系,常用 import、export 方法。

ES6新特性有那些?

新增命令let、const

  1. 新增声明命令 let 和 const
    • let 和 const 都是块级作用域,let 表示变量、const 表示常量;
    • 以{ }代码块作为作用域范围;
    • 只能在代码块里面使用不存在变量提升;
    • 只能先声明再使用,否则会报错;

模版字符串

  1. 模板字符串

    • 用一对反引号( `` )标识,它可以当作普通字符串使用,也可以用来定义多行字符串,也可以在字符串中嵌入变量js 表达式函数变量

    • js 表达式函数需要写在${ }中。

    • // 基本模板字符串
      const name = 'Alice';
      const greeting = `Hello, ${name}!`;
      console.log(greeting); // 输出: Hello, Alice!
      
      // 多行模板字符串
      const message = `
        Welcome to the site!
        Please enjoy your visit.`;
      console.log(message);
        // 输出:
        // Welcome to the site!
        // Please enjoy your visit.
      
      // 嵌入表达式
      const age = 25;
      const description = `I am ${age} years old.`;
      console.log(description); // 输出: I am 25 years old.
      

函数的扩展

函数的扩展

  1. ES6 为参数提供了默认值。(在定义函数时便初始化了这个参数,以便在参数没有被传递进去时使用。)

  2. 箭头函数

    • 写法

      • 当函数体中只有一个表达式时,{ }和 return 可以省略。
      // 箭头函数,只有一个表达式,隐式返回结果
      const square = x => x * x;
      
      • 当函数体中形参只有一个时,( )可以省略。

      • 函数名=(形参)=>{……}
        
    • 特点

      • 箭头函数中的 this 始终指向箭头函数定义时的离 this 最近的一个函数,如果没有最近的函数就指向window。

      • 没有独立的this:箭头函数的 this 值在函数定义时就已经确定,而不是在函数调用时确定。

      • 不能够使用 arguments 对象;

        不能用作构造函数,这就是说不能够使用 new 命令,否则会抛出一个错误;

在传统函数中,this 的值取决于函数是如何被调用的:

const person = {
  name: 'Alice',
  greet: function() {
    console.log('Hello, ' + this.name);
  }
};

const anotherPerson = {
  name: 'Bob'
};

// 将 greet 方法赋值给 anotherPerson
anotherPerson.greet = person.greet;

anotherPerson.greet(); // 输出: Hello, Alice

对于箭头函数,this 就不是指向 window,而是父级(指向是可变的)

const person = {
  name: 'Alice',
  greet: () => {
    console.log('Hello, ' + this.name);
  }
};

const anotherPerson = {
  name: 'Bob'
};

// 将 greet 方法赋值给 anotherPerson
anotherPerson.greet = person.greet;

anotherPerson.greet(); // 输出: Hello, Bob

对象的扩展

对象的扩展

  1. 属性的简写:ES6 允许在对象之中,直接写变量。这时,属性名为变量名, 属性值为变量的值。
  2. 方法的简写:省略冒号与 function 关键字。

for…of 循环

import 和 export

  • export 用于导出模块(对外输出本模块(一个文件可以理解为一个模块)变量的接口)
  • import 用于导入模块(在一个模块中加载另一个含有 export 接口的模块)

Promise 对象

  • Promise 是异步编程的一种解决方案,将异步操作以同步操作的流程表达出来。
  • 避免了层层嵌套的回调函数,解决了回调地狱的问题。
  • Promise 的 3 种状态

async、await`:使用 async/await, 搭配 Promise,可以通过编写形似同步的代码来处理异步流程

解构赋值

解构赋值:解构赋值是对赋值运算符的扩展,是一种针对数组或者对象进行模式匹配,然后对其中的变量进行赋值。

  • 数组解构:当你有一个数组,并且想要将数组中的元素赋值给不同的变量时,可以使用数组解构。

    const numbers = [1, 2, 3];
    const [a, b, c] = numbers;
    
    console.log(a); // 1
    console.log(b); // 2
    console.log(c); // 3
    

    对象解构:对象解构允许你从对象中提取属性值并赋给变量,变量名应与对象的属性名相对应。

    const user = {
      name: 'Alice',
      age: 25,
      country: 'Wonderland'
    };
    
    const { name, age, country } = user;
    
    console.log(name);    // Alice
    console.log(age);     // 25
    console.log(country); // Wonderland
    

Set 数据结构

Set 数据结构:类似数组。所有的数据都是唯一的,没有重复的值。(它本身是一个构造函数。)

  • Set 属性和方法

    • Size() 数据的长度
    • Add() 添加某个值,返回 Set 结构本身。
    • Delete() 删除某个值,返回一个布尔值,表示删除是否成功。
    • Has() 查找某条数据,返回一个布尔值。
    • Clear()清除所有成员,没有返回值。
  • 主要应用场景:数组去重

介绍下 Set、Map 的区别:

​ 应用场景 :Set 用于数据重组,Map 用于数据储存。

Set:

  • 成员不能重复
  • 只有键值没有键名,类似数组
  • 可以遍历,方法有 add, delete,has

Map:

  • 本质上是健值对的集合,类似集合
  • 可以遍历,可以跟各种数据格式转换

展开运算符

(展开运算符):可以将数组或对象里面的值展开;还可以将多个值收集为一个变量。

Symbol类型

Symbol类型:是一种基本类型。Symbol 通过调用 symbol 函数产生,它接收一个可选的名字参数,该函数返回的 symbol 是唯一的。

Proxy

Proxy:使用代理(Proxy)监听对象的操作

  1. 继承

ES6和ES5继承的区别

  • ES5 的继承是通过原型或者是构造函数机制来实现。

  • ES6 可以使用class关键字来定义类,并通过extends关键字实现继承。 【子类必须在 constructor 方法中调用 super 方法。】

    class Animal {	// 定义基类
      constructor(name) {
        this.name = name;
      }
    }
    
    class Dog extends Animal {	// 定义派生类,继承自 Animal
      bark() {
        return `${this.name} barks.`;
      }
    }
    
    const dog = new Dog('Buddy');	// 创建 Dog 类的实例
    	console.log(dog.bark()); //使用派生类的方法输出: Buddy barks.
    

ES6 如何转化为 ES5?

为什么要转化?

因为有些浏览器对ES6的兼容程度并不友好。

使用Babel来实现转化:babel 是一个 ES6 转码器,可以将 ES6 代码转为 ES5 代码,以便兼容那些还没支持 ES6的平台。

步骤:

  1. 使用npm安装转换插件babel-cli,在js文件中引入插件
  2. 创建babel-cli配置文件.babelrc,输入以下内容
    image-20240725183758655
  3. 在终端输入babelsrc/index.js-odist/index.js(src为开发路径,即ES6所在目录,dist为转换后ES5路径)

let、const、var的区别

  • var 声明变量可以重复声明,而 let 不可以重复声明

  • var 是不受限于块级的,而 let 是受限于块级

  • var 会与 window 相映射(会挂一个属性),而 let 不与 window 相映射

  • var 可以在声明的上面访问变量,而 let 有暂存死区,在声明的上面访问变量会报错

  • const 声明之后必须赋值,否则会报错

  • const 定义不可变的量,改变了就会报错

  • const 和 let 一样不会与 window 相映射、支持块级作用域、在声明的上面访问变量会报错

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

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

相关文章

基于Delaunay三角网的平面点云面积计算(python)

1、背景介绍 三维点云密度比较高,可以根据点云数据精确计算物体表面面积,如建筑物水平占地面积、室内房间墙面面积等,如下图,这在实际应用中具有非常重要的作用。其实归根到底,计算上述面积,可以认为计算平…

【Linux】基本指令1

文章目录 1. find2. which3. alias4.whereis5.grep6. sort 、uniq7. linux怎么编辑文件中的内容 1. find 1.1 find: 查找文件所在的位置。(当我们进行find搜索的时候,可能需要访问磁盘进而导致效率低下。) 1.2 find / file.txt 在Linux系统是…

掏耳神器哪种最好用?力荐四款优质高口碑产品

要说到掏耳神器,市面上有不少声称能掏掏干净耳垢的挖耳勺。例如棉签、螺旋掏耳勺、可视掏耳勺等。那么那种掏耳神器最好用呢?有着多年采耳经验的我,当然把这三种神器都买来尝试过,很明确地告诉大家,只有可视掏耳勺最好…

Oracle集群RAC磁盘管理命令asmcmd的使用

文章目录 ASM磁盘共享简介ASM磁盘共享的优势ASM磁盘组成ASM磁盘共享的应用场景Asmcmd简介Asmcmd的功能Asmcmd的命令Asmcmd的使用注意事项Asmcmd运行模式交互模式运行非交互模式运行ASMCMD命令分类实例管理命令:文件管理命令:磁盘组管理命令:模板管理命令:文件访问管理命令:…

云计算实训室建设可行性报告

一、建设云计算实训室的目的和意义 随着信息技术的飞速发展,云计算作为一种新型的信息服务模式,已经成为推动信息技术创新和促进信息产业发展的重要力量。中高职院校作为培养高素质技能人才的重要基地,应当紧跟时代步伐,加强云计…

com.mysql.cj.jdbc.Driver 爆红

出现这样的问题就是pom.xml文件中没有添加数据库依赖坐标 添加上这个依赖即可,添加完后重新加载一下Maven即可。 如果感觉对你有用就点个赞!!!

第三十二天 Emmet语法生成HTML标签

前身是zen coding 用缩写提高写代码效率 vscode已经集成该语法 写div直接按tab自动生成<div></div>标签 div*3 再按tab 就可以一下生成四个该标签 父子级的标签 例如ul>li div>span 兄弟关系 divp 生成带类名或者id 输入.as 产生 输入#id 产生 默认是div…

如何用 Python 处理和操作 CSV 文件?

CSV&#xff08;Comma-Separated Values&#xff09;文件是一种常见的数据存储格式&#xff0c;广泛用于数据交换和轻量级数据存储。CSV文件以纯文本格式存储表格数据&#xff0c;每一行代表一条记录&#xff0c;字段之间用逗号&#xff08;或其他分隔符&#xff09;分隔。Pyth…

数据结构(5):树和二叉树

1 树的定义 1.1 树的基本概念 分支可以称为边&#xff0c;结点可以用于存放数据结构。 除了根节点&#xff0c;其他节点只有一个前驱&#xff01;&#xff01;&#xff01;&#xff01; 互不相交也就是 只有一个前驱结点&#xff01; 树应用的很广的 1.2 结点之间的关系 直接…

微服务实践和总结

H5原生组件web Component Web Component 是一种用于构建可复用用户界面组件的技术&#xff0c;开发者可以创建自定义的 HTML 标签&#xff0c;并将其封装为包含逻辑和样式的独立组件&#xff0c;从而在任何 Web 应用中重复使用。 <!DOCTYPE html> <html><head…

Python | Leetcode Python题解之第283题移动零

题目&#xff1a; 题解&#xff1a; class Solution:def moveZeroes(self, nums: List[int]) -> None:n len(nums)left right 0while right < n:if nums[right] ! 0:nums[left], nums[right] nums[right], nums[left]left 1right 1

springboot游戏化教育平台-计算机毕业设计源码92424

游戏化教育平台设计与实现 摘 要 游戏化教育平台是一种融合了游戏元素和教育内容的创新型教育工具&#xff0c;旨在提升学习者的学习兴趣和参与度。本论文基于SpringBoot框架&#xff0c;设计并实现了一款游戏化教育平台。该平台包括用户和管理员两大功能模块。对于用户功能而…

Linux开启coredump

在Linux系统中&#xff0c;C/C程序崩溃是常见的问题之一。Coredump是指当一个程序崩溃时&#xff0c;系统把程序运行时的内存数据以二进制文件的形式保存下来&#xff0c;以便程序开发者进行崩溃分析。本文将介绍如何开启并配置Coredump 1、查看并配置coredump 在Linux系统中…

mac M1安装Roop教程及所遇到的问题

1.安装miniconda&#xff0c;下载地址&#xff1a; 按 Python 版本划分的最新 Miniconda 安装程序链接&#xff1a;https://docs.anaconda.com/miniconda/miniconda-other-installer-links/ 下载后直接默认安装即可。 我用的是&#xff1a;Python3.10对应的Miniconda 2.下载…

在 ArchLinux 上编译运行 axmol 引擎

本文将在 Windows 10 上安装 Arch WSL 中编译 axmol 请确保 WSL2 已正确安装 1. 在微软应用商店安装 ArchLinux 2. 打开 Arch&#xff0c;按照提示输入用户名和密码&#xff0c;尽量简单 3. 配置清华源&#xff0c;速度快的起飞&#xff0c;否则&#xff0c;各种包会安装失败…

C++必修:模拟实现STL之string

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ &#x1f388;&#x1f388;养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; 所属专栏&#xff1a;C学习 贝蒂的主页&#xff1a;Betty’s blog 为了让我们更加深入理解string&#xff0c;接下来我们将模拟实现一个简易版的stri…

力扣高频SQL 50题(基础版)第十七题

文章目录 力扣高频SQL 50题&#xff08;基础版&#xff09;第十七题1075. 项目员工 I题目说明思路分析实现过程准备数据实现方式结果截图 力扣高频SQL 50题&#xff08;基础版&#xff09;第十七题 1075. 项目员工 I 题目说明 项目表 Project&#xff1a; ----------------…

四、GD32 MCU 常见外设介绍 (2) GPIO 模块介绍

2.GPIO 模块介绍 GPIO的全称为通用输入输出口&#xff0c;是很多外设能够正常工作的必要条件。除了一些特定功能的引脚(如电源脚)外&#xff0c;MCU上其他的引脚都可以当做GPIO来使用。本章&#xff0c;我们将对GPIO进行简单介绍&#xff0c;并通过一个“流水灯”的实验来熟悉…

力扣刷题-图论-岛屿类问题-集合实现(c++实现)

我的老师&#xff1a;力扣链接这道题题解中最高赞的回答nettee&#xff0c;从这篇题解中我学到了dfs框架以及解决思路&#xff0c;并独立完成了该题解里的几道习题本人刷题的习惯是学会一个板子&#xff0c;然后之后的同类题都机械的用这个板子去做&#xff0c;最好不做创新&am…

广州某展厅门牌创新案例:1*2 OLED柔性屏的精致应用

在广州这座繁华都市的心脏地带&#xff0c;一座现代感十足的展厅悄然矗立&#xff0c;其独特的门牌设计成为了过往行人目光的焦点。这座展厅的门牌采用了前沿的1*2 OLED柔性屏技术&#xff0c;不仅展现了科技与艺术的完美融合&#xff0c;更彰显了展厅的高端定位与创新精神。 项…