No24.精选前端面试题,享受每天的挑战和学习

简介: No24.精选前端面试题,享受每天的挑战和学习

TypeScript的元组(Tuple)、接口(Interface)、枚举(Enum)

当谈到 TypeScript(TS)时,元组(Tuple)、接口(Interface)和枚举(Enum)是三个重要的概念

元组(Tuple)

元组是 TypeScript 中的一种特殊数据类型,它允许您存储具有固定数量和特定类型的元素的数组

  • 元组中的每个元素可以具有不同的类型
  • 元组使用固定的索引位置来访问其元素。

以下是一个元组的示例:

let person: [string, number] = ['John', 30];

在上述例子中,person 是一个包含两个元素的元组类型,第一个元素是一个字符串类型,第二个元素是一个数字类型。

请注意,元组的长度是固定的,且不能动态增加或减少。此外,您可以使用 push() 方法向元组中添加新元素,但不推荐使用该方法,因为它会破坏元组的类型约束

接口(Interface)

接口可以在 TypeScript 中定义【对象的结构】或【类的形状】。

它们用于定义类型的契约,规定了对象应该具有哪些属性、方法、以及它们的类型

以下是一个接口的示例:

interface Person {
  name: string;
  age: number;
  greet: () => void;
}
let person: Person = {
  name: 'John',
  age: 30,
  greet() {
    console.log(`Hello, my name is ${this.name}`);
  }
};

在上述例子中,Person 是一个接口,规定了一个人的结构应包含 nameage 属性,以及一个无返回值的 greet 方法。

接口非常有用,因为它们能够帮助我们【定义和强制类型的一致性】,以及提供【代码提示】和【静态类型检查】。

枚举(Enum)

枚举是一种类型,用于定义一组命名的常量

它们使代码更具可读性和可维护性。

通过使用枚举,我们可以将一组相关的常量放在一起,并通过名称来引用它们。

以下是一个枚举的示例:

enum Color {
  Red,
  Green,
  Blue
}
let favoriteColor: Color = Color.Blue;
console.log(favoriteColor);  // 输出:2

在上述例子中,Color 是一个枚举,定义了三个常量:RedGreenBlue,它们分别对应的值是 0、1 和 2。我们可以使用枚举来表示颜色,并将其赋值给变量 favoriteColor

枚举可以具有初始值,也可以指定每个常量的值。例如,enum Color { Red = 1, Green = 2, Blue = 4 } 会将 Red 设置为 1,Green 设置为 2,Blue 设置为 4。

JS 如何动态获取本地文件夹中的所有图片

在 JavaScript 中,要动态获取本地文件夹中的所有图片,您需要使用文件读取的 API。

以下是一种可以实现这个目标的基本方法:

<input type="file" id="file-input" multiple accept="image/*">
<script>
  document.getElementById('file-input').addEventListener('change', handleFileSelect, false);
  function handleFileSelect(event) {
    const files = event.target.files;
    for (let i = 0; i < files.length; i++) {
      const file = files[i];
      if (file.type.match('image.*')) {
        const reader = new FileReader();
        reader.onload = function(e) {
          const image = new Image();
          image.src = e.target.result;
          document.body.appendChild(image);
        };
        reader.readAsDataURL(file);
      }
    }
  }
</script>

上述代码段包含一个带有 multiple 属性的文件输入字段和一个将选定的图片显示在页面上的函数 handleFileSelect。用户可以通过单击文件输入字段并选择一个或多个图像文件。

当用户选择文件后,handleFileSelect 函数会将每个图像文件读取为数据 URL,并使用 Image 对象动态创建一个图片元素,并将其附加到 document.body 上。这样,您就可以在页面上看到选定的图像。

请注意,由于安全限制,JavaScript 无法直接访问用户的本地文件系统,因此您需要通过用户手动选择文件来获取图像。以上示例仅适用于浏览器环境,不能在服务器端运行。

浅谈一下 webpack 以及 loader 和 plugin

Webpack 是一个现代的前端打包工具,它主要用于将多个模块(JavaScript、CSS、图像等)打包成一个或多个静态资源文件。Webpack 提供了丰富的功能和灵活的配置选项,可帮助我们管理和优化前端项目。

Loader 是 Webpack 中用于转换和处理各种类型模块的工具。

它们允许我们在构建过程中对模块应用各种转换,例如

  • 编译 ES6+ JavaScript
  • 处理 CSS 预处理器
  • 压缩图像

每个 Loader 将源文件作为输入,并输出转换后的文件。

以下是一些常用的 Loader 示例:

  • Babel Loader:将 ES6+ 代码转换为向后兼容的 JavaScript 版本。
  • CSS Loader:解析 CSS 文件,并处理其中的导入、URL 引用等。
  • Style Loader:将 CSS 样式注入到 HTML 页面中。
  • File Loader:将文件复制到输出目录并返回其路径。
  • Image LoaderImage Webpack Loader:优化和压缩图像文件。

Plugin 是 Webpack 的扩展机制

它可以用于执行更广泛范围的任务,例如打包优化、资源管理、注入环境变量等。Plugins 通过钩子机制与 Webpack 的构建流程进行交互,它们可以监听构建过程的事件,并在特定的时机执行自定义逻辑。

以下是一些常用的 Plugin 示例:

  • HtmlWebpackPlugin:为生成的 HTML 文件添加自动引入打包后的资源文件的功能。
  • MiniCssExtractPlugin:将 CSS 从 JS 中提取为独立的文件。
  • CleanWebpackPlugin:在每次构建前清理输出目录。
  • DefinePlugin:允许定义全局常量,用于在编译过程中替换代码中的文本。
  • UglifyJsPlugin:压缩 JavaScript 代码。

除了上述示例外,还有许多其他的 LoaderPlugin 可供使用,可以根据项目需求选择和配置。

通过使用 WebpackLoaderPlugin,我们能够自动处理、转换和优化前端项目中的各种资源,提高开发效率和性能,同时也为项目提供了更好的可扩展性。

Event Loop 事件循环简介

事件循环(Event Loop)是 JavaScript 的一种执行模型,用于管理异步操作和回调函数的执行顺序

它是解决 JavaScript 单线程执行的一种机制。

在 JavaScript 中,除了同步任务外,还存在异步任务,比如定时器回调、网络请求、事件处理等。当遇到异步任务时,JavaScript 引擎将会将其交给相应的异步 API 处理,并在异步任务完成后,将对应的回调函数放入任务队列中。

事件循环负责监控调用栈和任务队列,并在调用栈为空时,从任务队列中取出任务并执行。

具体的执行过程可以分为以下几个步骤:

  1. 执行全局同步代码,初始化进入主线程
  2. 当遇到异步任务时,将其交给相应的异步 API 处理,并注册对应的回调函数。
  3. 异步任务在一定的条件下(定时器到期、网络请求完成、事件触发等)被推入任务队列中。
  4. 调用栈为空时,事件循环会从任务队列中取出一个任务
  5. 任务压入调用栈中执行。
  6. 回到步骤 1,继续检查和执行任务队列中的任务。

这个过程就是事件循环的基本流程,确保了 JavaScript 在单线程的情况下能够处理异步任务并保持响应性。

任务队列分为宏任务(macro-task)和微任务(micro-task)

  • 常见的宏任务包括 setTimeout、setInterval、I/O 操作
  • 微任务包括 PromiseMutationObserver

在每一次事件循环中,所有的微任务会在下一个宏任务之前执行完毕。

理解事件循环对于编写高效的、避免阻塞的 JavaScript 代码非常重要。合理地使用异步操作和避免长时间运行的同步操作可以提高页面的响应性能和用户体验。

相关文章
|
22天前
|
存储 XML 移动开发
前端大厂面试真题
前端大厂面试真题
|
5天前
|
网络协议 算法 数据库
|
23天前
|
前端开发 Java 编译器
【前端学java】如何从前端视角快速学习Maven
【8月更文挑战第12天】如何从前端视角快速学习Maven
36 2
【前端学java】如何从前端视角快速学习Maven
|
24天前
|
前端开发 JavaScript API
前端框架Vue------>第二天学习(1)插槽
这篇文章介绍了Vue框架中插槽(slot)的概念和用法,以及如何在组件中使用自定义事件进行父子组件间的通信。
前端框架Vue------>第二天学习(1)插槽
|
10天前
|
前端开发 算法 网络协议
如何学习计算机基础知识,打好前端和网络安全的基础
如何学习计算机基础知识,打好前端和网络安全的基础
23 4
|
18天前
|
存储 前端开发 JavaScript
44 个 React 前端面试问题
【8月更文挑战第18天】
20 2
|
18天前
|
存储 JavaScript 前端开发
2022年前端js面试题
2022年前端js面试题
16 0
|
20天前
|
存储 前端开发 JavaScript
44 个 React 前端面试问题
44 个 React 前端面试问题
|
23天前
|
前端开发 JavaScript
前端网站学习大全
这篇文章提供了前端网站开发学习的资源大全,涵盖了HTML常用标签和CSS常用样式,以及如何使用`<meta>`标签提供页面元信息和`lang`属性定义内容语言等基础知识。
前端网站学习大全
|
24天前
|
前端开发 JavaScript
前端框架Vue------>第三天学习(1)
这篇文章介绍了Vue框架的组件基础和计算属性的概念,通过示例代码展示了如何定义可复用的Vue组件和使用计算属性来声明性地描述依赖其他值的数据。
下一篇
DDNS