[前端]NodeJS常见面试题目

什么是非阻塞 I/O? Node.js 如何实现非阻塞 I/O?

非阻塞 I/O 是一种编程模式,它允许 I/O 操作(如读取文件、网络请求等)在执行时不阻塞程序的其余部分。换句话说,当一个 I/O 操作发起后,程序可以立即继续执行其他任务,而不必等待该 I/O 操作完成。Node.js 天然采用了非阻塞 I/O 模型,这使得它特别适合 I/O 密集型应用,例如 Web 服务器、实时聊天应用等。

Node.js 实现非阻塞 I/O 的关键在于其事件驱动(Event-Driven)的架构和异步操作。Node.js 通过其核心模块 libuv 实现了事件循环(Event Loop),以处理异步 I/O 操作。当一个非阻塞 I/O 操作启动时,Node.js 会向操作系统发起相应的系统调用,并将回调函数注册到事件循环中。事件循环不断检查是否有完成的 I/O 操作,一旦 I/O 操作完成,事件循环会将对应的回调函数放入执行队列中以便后续执行。

Node.js 中的回调、Promise 和 async/await 有什么区别?

  • 回调:回调函数是一种传统的处理异步操作的方式。在 Node.js 中,当一个异步操作完成时,会调用一个事先定义好的函数来处理结果。回调函数的缺点是容易导致代码难以维护,被称为“回调地狱”。
  • Promise:Promise 是为了解决回调地狱而引入的一种机制。Promise 对象代表了一个异步操作的最终完成(或失败)及其结果值。Promise 提供了链式调用的方式,使得异步代码更加清晰和易于维护。
  • async/await:async/await 是基于 Promise 实现的,它使得异步代码看起来更像是同步代码。async 函数会隐式地返回一个 Promise,而 await 关键字则用于等待 Promise 的解决。使用 async/await 可以让异步代码更加简洁和直观,同时避免了回调地狱的问题。

如何在 Node.js 中进行错误处理,特别是在异步代码中?

在 Node.js 中进行错误处理,特别是在异步代码中,可以采用以下几种方式:

  • try-catch 语句:在同步代码中使用 try-catch 语句可以捕获并处理错误。但在异步代码中,try-catch 语句无法直接捕获异步操作中的错误。
  • Promise 的错误处理:Promise 提供了 .catch() 方法来处理错误。当 Promise 被拒绝时,.catch() 方法会被调用,并接收一个错误对象作为参数。
  • async/await 的错误处理:使用 async/await 时,可以使用 try-catch 语句来捕获异步操作中的错误。当异步操作(即 await 表达式)失败时,会抛出错误,并被 try-catch 语句捕获。

什么是 Stream 流? 举例说明如何在 Node.js 中使用流处理数据?

Stream 是 Node.js 中用于处理数据的抽象接口,可以在读取和写入数据时以逐块(chunk)的方式进行操作。流可以分为可读流和可写流两种类型。

  • 可读流(Readable Stream):用于从数据源(比如文件、网络请求、标准输入等)读取数据,可以以可控的方式一次读取一小块数据,而不是一次性读取整个文件或数据流。
  • 可写流(Writable Stream):用于将数据写入目标位置(比如文件、网络响应、标准输出等),也是逐块写入的方式,可以分多次写入数据。

在 Node.js 中使用流处理数据的示例如下:

javascript复制代码

const fs = require('fs');
// 创建一个可读流来读取文件
const readableStream = fs.createReadStream('input.txt', { encoding: 'utf8' });
// 创建一个可写流来写入文件
const writableStream = fs.createWriteStream('output.txt', { encoding: 'utf8' });
// 将可读流的数据通过管道传输到可写流
readableStream.pipe(writableStream);
readableStream.on('end', () => {
console.log('文件读取和写入完成');
});

在这个示例中,我们使用 fs.createReadStream 创建一个可读流来读取 input.txt 文件,使用 fs.createWriteStream 创建一个可写流来写入 output.txt 文件。然后,我们使用 pipe 方法将可读流的数据传输到可写流中。当可读流读取完文件并结束时,会触发 end 事件,我们在事件处理函数中打印一条消息表示文件读取和写入完成。

其他问题简要回答

  1. 什么是集群? 如何在 Node.js 中实现集群和负载均衡?

    • 集群是指将多个服务器组合起来,共同处理客户端的请求。在 Node.js 中,可以使用 cluster 模块来实现集群和负载均衡。通过创建多个工作进程来分担负载,从而提高应用程序的吞吐量和响应速度。
  2. 如何调试 Node.js 程序? 有哪些方法?

    • 调试 Node.js 程序可以使用多种方法,包括使用 Node.js 内置的调试器、第三方调试工具(如 Visual Studio Code 的调试功能)、在代码中添加 console.log 语句进行日志输出等。
  3. 在 Node.js 中,如何避免回调地狱?

    • 可以使用 Promise 和 async/await 来避免回调地狱。Promise 提供了链式调用的方式,而 async/await 则使得异步代码看起来更像是同步代码,从而避免了回调地狱的问题。
  4. 如何在 Node.js 中处理多线程或多进程操作?

    • Node.js 是单线程的,但它支持多进程操作。可以使用 child_process 模块来创建子进程,或者使用 cluster 模块来创建多个工作进程来处理并发请求。对于多线程操作,可以使用 Node.js 的 worker_threads 模块来实现。
  5. 什么是模块依赖循环? 如何在 Node.js 中避免或解决它?

    • 模块依赖循环是指两个或多个模块相互依赖,形成一个闭环。这可能导致模块加载失败或行为异常。为了避免或解决模块依赖循环,可以重新组织代码结构,将相关的功能拆分到不同的模块中,并确保模块之间的依赖关系清晰且没有循环。
  6. 如何在 Node.js 中实现文件的压缩和解压缩?

    • 可以使用第三方库(如 archiverunzipper 等)来实现文件的压缩和解压缩。这些库提供了简单易用的 API,可以方便地处理各种压缩格式(如 ZIP、TAR 等)。
  7. 有哪些常用的 Node.js 测试框架? 如何编写测试用例?

    • 常用的 Node.js 测试框架包括 Mocha、Jest、Jasmine 等。编写测试用例时,需要定义测试场景、输入数据和预期结果,并使用测试框架提供的断言函数来验证实际结果是否符合预期。
  8. 什么是 package-lock.json 文件? 它的作用是什么?

    • package-lock.json 文件是一个由 npm 生成的锁定文件,它记录了项目依赖的具体版本和依赖树。它的作用是确保项目在不同环境中使用相同版本的依赖项,从而避免由于依赖项版本不一致而导致的问题。
  9. 如何在 Node.js 中使用 Websocket 实现实时通信?

    • 可以使用 ws 或 socket.io 等库来实现 Websocket 通信。这些库提供了简单易用的 API,可以方便地创建 Websocket 服务器和客户端,并实现实时通信功能。
  10. 在 Node.js 中如何进行数据库操作,比如使用什么 DB 和 ORM?

    • 在 Node.js 中,可以使用多种数据库和 ORM(对象关系映射)工具来进行数据库操作。常用的数据库包括 MySQL、PostgreSQL、MongoDB 等,而常用的 ORM 工具包括 Sequelize、TypeORM、Mongoose 等。这些工具提供了简单易用的 API,可以方便地执行数据库查询和更新操作。
  11. ES6 模块和 CommonJs 模块在 Node.js 中有什么区别?

    • ES6 模块和 CommonJs 模块是两种不同的模块系统。ES6 模块使用 import 和 export 关键字来导入和导出模块成员,支持静态分析和更好的性能优化。而 CommonJs 模块使用 require 和 module.exports 来导入和导出模块成员,是 Node.js 早期使用的模块系统。在 Node.js 中,可以通过设置 "type": "module" 在 package.json 文件中来使用 ES6 模块系统。
  12. 在 Node.js 中如何处理文件上传和下载?

    • 可以使用第三方库(如 multeraxios 等)来处理文件上传和下载。multer 是一个用于处理 multipart/form-data 类型的文件上传的中间件,而 axios 则是一个用于发送 HTTP 请求的库,可以用于文件下载。
  13. 在 Node.js 中如何实现定时任务? 有哪些方法?

    • 在 Node.js 中,可以使用 setTimeout 和 setInterval 函数来实现简单的定时任务。此外,还可以使用第三方库(如 node-scheduleagenda 等)来实现更复杂的定时任务调度功能。

如何在 Node.js 中实现断言?

在 Node.js 中,可以使用内置的 assert 模块来实现断言。assert 模块提供了一系列用于执行断言的函数,这些函数可以在测试代码中用来验证假设是否为真。如果假设不为真,这些函数会抛出一个错误。

以下是一些常用的 assert 函数及其用法示例:

  1. assert(value, message): 测试 value 是否为真(即不是 false0""nullundefined 或 NaN)。如果不为真,则抛出错误,并显示 message

    javascript复制代码

    const assert = require('assert');
    assert(true, 'This will not throw');
    assert(false, 'This will throw: got false'); // 抛出错误
  2. assert.strictEqual(actual, expected, message): 测试 actual 是否严格等于(使用 ===expected。如果不相等,则抛出错误,并显示 message

     

    javascript复制代码

    assert.strictEqual(1, 1, '1 is strictly equal to 1');
    assert.strictEqual(1, '1', '1 is not strictly equal to "1"'); // 抛出错误
  3. assert.deepStrictEqual(actual, expected, message): 测试 actual 是否深度严格等于(递归比较)expected。如果不相等,则抛出错误,并显示 message

     

    javascript复制代码

    assert.deepStrictEqual({ a: 1 }, { a: 1 }, 'Objects are deeply equal');
    assert.deepStrictEqual({ a: 1 }, { a: '1' }, 'Objects are not deeply equal'); // 抛出错误
  4. assert.throws(block, error, message): 测试 block 是否抛出一个错误。如果 block 没有抛出错误或抛出的错误与 error 不匹配,则抛出错误,并显示 message

     

    javascript复制代码

    assert.throws(
    () => {
    throw new Error('Wrong value');
    },
    Error,
    'Thrown value should be an instance of Error'
    );
  5. assert.doesNotThrow(block, error, message): 测试 block 是否不抛出一个错误。如果 block 抛出了错误,则抛出错误,并显示 message

     

    javascript复制代码

    assert.doesNotThrow(
    () => {
    console.log('This will not throw');
    },
    Error,
    'This will not throw an error'
    );

如何在 Node.js 中实现纳秒级别的高精度计时?

Node.js 的标准库并没有直接提供纳秒级别的高精度计时功能,但可以使用 process.hrtime() 方法来获取高精度的时间。process.hrtime() 返回一个数组 [seconds, nanoseconds],表示从 Node.js 进程启动到现在所经过的时间。

虽然 process.hrtime() 返回的纳秒部分是一个整数,但由于其基于高精度时钟(通常是 CPU 周期计数器),因此具有纳秒级别的精度。

以下是一个使用 process.hrtime() 进行高精度计时的示例:

 

javascript复制代码

const start = process.hrtime();
// 模拟一些耗时操作
for (let i = 0; i < 1e9; i++) {
// 空循环,模拟耗时操作
}
const [seconds, nanoseconds] = process.hrtime(start);
const totalNanoseconds = seconds * 1e9 + nanoseconds;
console.log(`Elapsed time: ${totalNanoseconds} nanoseconds`);

在这个示例中,process.hrtime(start) 返回从开始时间到当前时间的差异,以秒和纳秒的形式表示。通过将这些值转换为总纳秒数,我们可以得到高精度的时间测量结果。

需要注意的是,虽然 process.hrtime() 提供了纳秒级别的精度,但由于系统调度和其他因素的影响,实际测量的时间可能会有所偏差。此外,process.hrtime() 返回的时间是基于 Node.js 进程启动时间的相对时间,而不是绝对时间。

如何在 Node.js 中实现数据的缓存,以提高性能?

在 Node.js 中,可以通过多种方式实现数据缓存,以提高性能。常用的方法包括:

  1. 内存缓存
    • 使用简单的 JavaScript 对象或 Map 存储数据。
    • 使用第三方库如 node-cache
  2. Redis
    • Redis 是一个高性能的键值存储系统,非常适合作为缓存层。
    • 可以通过 redis 客户端库与 Redis 进行交互。
  3. Memcached
    • Memcached 也是一个分布式内存对象缓存系统。
    • 使用 memcached 客户端库与 Memcached 进行交互。

什么是 Node.js 的中间件?有哪些常用的中间件?

中间件 是指请求和响应之间的处理函数,可以访问请求对象(req)、响应对象(res)以及应用程序的请求/响应周期中的下一个中间件函数。中间件的功能范围从执行代码、响应请求、结束请求-响应循环,到调用堆栈中的下一个中间件。

常用的中间件包括:

  • Express 中间件:如 body-parser 用于解析请求体,cookie-parser 用于解析 cookie。
  • Connect:一个轻量级的中间件框架,是 Express 的基础。
  • Morgan:用于记录 HTTP 请求日志。
  • Cors:用于处理跨域请求。

如何编写自定义的 Node.js 中间件?

在 Express 中,编写自定义中间件非常简单。中间件函数是一个接受三个参数的函数 (req, res, next)。你可以使用 next() 函数将控制权传递给下一个中间件。

 

javascript复制代码

const express = require('express');
const app = express();
// 自定义中间件
app.use((req, res, next) => {
console.log('请求时间:', Date.now());
next();
});
app.get('/', (req, res) => {
res.send('Hello World!');
});
app.listen(3000, () => {
console.log('服务器正在运行在 http://localhost:3000');
});

有哪些常用的 Node.js 开发框架?分别有什么特点?

  1. Express
    • 轻量级、灵活的 Node.js Web 应用框架。
    • 提供了一系列强大的特性来帮助你创建各种 Web 应用和 API。
  2. Koa
    • 新一代的 Node.js Web 框架,致力于成为更小、更富有表现力、更健壮的基础。
    • 使用中间件来处理请求和响应。
  3. Hapi (hapi.js)
    • 一个配置导向的框架,用于构建健壮、可扩展的 Node.js 应用程序。
    • 非常适合构建大型 API 和复杂的 Web 服务。
  4. NestJS
    • 一个用于构建高效、可靠和可扩展的服务器端应用程序的框架。
    • 使用 TypeScript(但也支持纯 JavaScript)和面向对象编程。

在 Node.js 中,如何处理静态文件的服务?

在 Express 中,可以使用 express.static 中间件来处理静态文件。

 

javascript复制代码

const express = require('express');
const app = express();
// 指定静态文件目录
app.use(express.static('public'));
app.listen(3000, () => {
console.log('服务器正在运行在 http://localhost:3000');
});

如何在 Node.js 中实现 OAuth 认证?

实现 OAuth 认证通常涉及以下步骤:

  1. 配置 OAuth 提供者(如 Google、GitHub 等)。
  2. 重定向用户到 OAuth 提供者的授权页面。
  3. 处理授权回调,获取访问令牌。
  4. 使用访问令牌访问受保护资源。

你可以使用第三方库如 passport 和 passport-oauth2 来简化这个过程。

Node.js 中的守护进程是如何实现的?

在 Node.js 中,守护进程(Daemon)通常是通过将进程分离到后台运行来实现的。你可以使用 child_process 模块来创建子进程,并将其设置为守护进程。

 

javascript复制代码

const { fork } = require('child_process');
const child = fork('path/to/your/script.js', [], {
detached: true,
stdio: ['ignore', 'ignore', 'ignore', 'ipc']
});
child.unref();

如何在 Node.js 中处理文件系统的监控,例如检测文件的变化?

你可以使用 fs.watch 或 fs.watchFile 来监控文件和目录的变化。

 

javascript复制代码

const fs = require('fs');
fs.watch('path/to/directory', (eventType, filename) => {
if (filename) {
console.log(`文件 ${filename} 被 ${eventType}`);
} else {
console.log(`目录被 ${eventType}`);
}
});

在 Node.js 中如何使用 worker threads 模块?

worker_threads 模块允许你在 Node.js 中使用多线程。你可以通过创建 Worker 实例来运行并行任务。

 

javascript复制代码

const { Worker, isMainThread, parentPort, workerData } = require('worker_threads');
if (isMainThread) {
// 在主线程中
const worker = new Worker(__filename, {
workerData: { someKey: 'someValue' }
});
worker.on('message', (message) => {
console.log('主线程收到消息:', message);
});
worker.on('error', (error) => {
console.error('工作线程出错:', error);
});
worker.on('exit', (code) => {
if (code !== 0)
console.error(`工作线程停止,退出码 ${code}`);
});
} else {
// 在工作线程中
console.log('工作线程数据:', workerData);
// 发送消息给主线程
parentPort.postMessage('工作线程完成');
}

在 Node.js 中,如何实现应用程序的国际化(i18n)?

可以使用第三方库如 i18next 来实现国际化。

 

javascript复制代码

const i18n = require('i18next');
const backend = require('i18next-fs-backend');
i18n
.use(backend)
.init({
lng: 'en', // 语言
fallbackLng: 'en', // 回退语言
backend: {
// 配置文件系统后端
loadPath: './locales/{{lng}}/{{ns}}.json'
}
});
i18n.t('welcome'); // 获取翻译后的文本

如何在 Node.js 中处理和解析二进制数据?

可以使用 Buffer 类来处理二进制数据。

 

javascript复制代码

const buf = Buffer.from('Hello, world!', 'utf8');
console.log(buf.toString('hex')); // 打印十六进制表示
console.log(buf.toString('base64')); // 打印 Base64 表示

什么是模板引擎?如何在 Node.js 中使用模板引擎?

模板引擎 是一种允许你生成动态内容的工具,通常用于生成 HTML。在 Node.js 中,常用的模板引擎包括 Pug(之前叫 Jade)、EJS、Handlebars 等。

使用 Pug 示例:

 

javascript复制代码

const express = require('express');
const app = express();
const pug = require('pug');
app.set('view engine', 'pug');
app.get('/', (req, res) => {
res.render('index', { title: 'My Page', message: 'Hello, world!' });
});
app.listen(3000, () => {
console.log('服务器正在运行在 http://localhost:3000');
});

如何在 Node.js 中使用 Redis 实现数据缓存?

你可以使用 redis 客户端库与 Redis 进行交互。

 

javascript复制代码

const redis = require('redis');
const client = redis.createClient();
client.on('error', (err) => {
console.error('Redis 客户端错误:', err);
});
client.set('key', 'value', redis.print);
client.get('key', (err, reply) => {
console.log('Redis 回复:', reply); // 输出 'value'
client.quit();
});

在 Node.js 中,如何使用 JWT 进行用户认证?

可以使用 jsonwebtoken 库来生成和验证 JWT。

 

javascript复制代码

const jwt = require('jsonwebtoken');
// 生成令牌
const token = jwt.sign({ user: 'user123' }, 'your-secret-key', { expiresIn: '1h' });
console.log('生成的令牌:', token);
// 验证令牌
jwt.verify(token, 'your-secret-key', (err, decoded) => {
if (err) {
return console.error('令牌验证失败:', err.message);
}

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

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

相关文章

MySQL技巧之跨服务器数据查询:进阶篇-从A数据库复制到B数据库的表中

MySQL技巧之跨服务器数据查询&#xff1a;进阶篇-从A数据库复制到B数据库的表中 基础篇已经描述&#xff1a;借用微软的SQL Server ODBC 即可实现MySQL跨服务器间的数据查询。 而且还介绍了如何获得一个在MS SQL Server 可以连接指定实例的MySQL数据库的连接名: MY_ODBC_MYSQ…

UVC 输出视频格式修改和windows下数据分析

文章目录 前言一、UVC MJPEG视频帧描述符1.MJPG视频帧格式示例 二、UVC YUV2、NV12、M420、I420无压缩视频帧描述符GUID1.如YUV2数据参数初始为: 三、UVC Windows下UVC摄像头数据分析总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 项目需要&#…

大数据开发面试宝典

312个问题&#xff0c;问题涵盖广、从自我介绍到大厂实战、19大主题&#xff0c;一网打尽、真正提高面试成功率 一、Linux 1. 说⼀下linux的常⽤命令&#xff1f; 说一些高级命令即可 systemctl 设置系统参数 如&#xff1a;systemctl stop firewalld关闭防火墙 tail / hea…

更改Ubuntu22.04锁屏壁纸

更改Ubuntu22.04锁屏壁纸 sudo apt install gnome-shell-extensions gnome-shell-extension-manager安装Gnome Shell 扩展管理器后&#xff0c;打开“扩展管理器”并使用搜索栏找到“锁屏背景”扩展

GxtWaitCursor:Qt下基于RAII的鼠标等待光标类

有时我们需要以阻塞的方式执行一点耗时的操作&#xff0c;这时需要主窗口光标呈现忙状态&#xff0c;GxtWaitCursor正是为此设计&#xff1b;重载的构造函数&#xff0c;可以让光标呈现忙状态一定时间后自动恢复。 GxtWaitCursor.h #pragma once#include <QObject>// // …

Unity3D实现视频和模型融合效果

系列文章目录 unity工具 文章目录 系列文章目录👉前言👉一、效果展示如下👉二、VideoPlayer播放视频(一)👉2-1、Hieraechy面板右键创建videoPlayer👉2-2、Assets面板右键创建RenderTexture👉2-3、把设置好的RenderTexture拖到videoPlayer里面还有本地视频视频�…

探索Pillow库:Python图像处理的瑞士军刀

文章目录 **探索Pillow库&#xff1a;Python图像处理的瑞士军刀**1. 背景&#xff1a;为何选择Pillow&#xff1f;2. Pillow是什么&#xff1f;3. 如何安装Pillow&#xff1f;4. 五个简单的库函数使用方法4.1 打开图像4.2 显示图像4.3 转换图像格式4.4 调整图像大小4.5 旋转图像…

HelloMeme 上手即用教程

HelloMeme是一个集成空间编织注意力的扩散模型&#xff0c;用于生成高保真图像和视频。它提供了一个代码库&#xff0c;包含实验代码和预训练模型&#xff0c;支持PyTorch和FFmpeg。用户可以通过简单的命令行操作来生成图像和视频。 本文将详细介绍&#xff0c;如何在GPU算力租…

JVM详解:JVM的系统架构

计算机语言大致可以分为两类&#xff0c;一直是编译性语言&#xff0c;典型的如C&#xff0c;他会先有编译器编译成可执行文件&#xff08;操作系统可读&#xff0c;不同的操作系统需要编译成不同的可执行文件&#xff09;&#xff0c;而另一种则是翻译性语言&#xff0c;这种语…

21. Drag-Drop拖放操作(二) - 文件、表格和树的拖放实现

本了继上节内容&#xff0c;讲述几种常用的拖放场景示例&#xff0c;包括文件、表格和树的拖放实现。 文件拖放 实现从系统目录拖放文件到App中。 自定义接收视图 自定义应用内部接收拖放的view视图类FileDragView&#xff0c;注册拖放类型&#xff0c;实现目标拖放协议NS…

力扣515:在每个树行中找最大值

给定一棵二叉树的根节点 root &#xff0c;请找出该二叉树中每一层的最大值。 示例1&#xff1a; 输入: root [1,3,2,5,3,null,9] 输出: [1,3,9]示例2&#xff1a; 输入: root [1,2,3] 输出: [1,3]提示&#xff1a; 二叉树的节点个数的范围是 [0,104]-231 < Node.val &l…

vivo 游戏中心包体积优化方案与实践

作者&#xff1a;来自 vivo 互联网大前端团队- Ke Jie 介绍 App 包体积优化的必要性&#xff0c;游戏中心 App 在实际优化过程中的有效措施&#xff0c;包括一些优化建议以及优化思路。 一、包体积优化的必要性 安装包大小与下载转化率的关系大致是成反比的&#xff0c;即安装…

数据库SQL——连接表达式(JOIN)图解

目录 一、基本概念 二、常见类型 内连接&#xff08;INNER JOIN&#xff09;&#xff1a; 左连接&#xff08;LEFT JOIN 或 LEFT OUTER JOIN&#xff09;&#xff1a; 右连接&#xff08;RIGHT JOIN 或 RIGHT OUTER JOIN&#xff09;&#xff1a; 全连接&#xff08;FULL…

Sigrity SPEED2000 Power Ground Noise Simulation模式如何查看PDS系统的自阻抗操作指导

Sigrity SPEED2000 Power Ground Noise Simulation模式如何查看PDS系统的自阻抗操作指导 Sigrity Power SI Power Ground Noise Simulation模式可以用于PDS系统自阻抗分析,以下图为例 2D视图

uni-app移动端与PC端兼容预览PDF文件

过程遇到的问题 1、如果用的是最新的版本的pdfjs的话&#xff0c;就会报Promise.withResolvers 不是一个方法的错误&#xff0c;原因是Promise.withResolvers是ES15新特性&#xff0c;想了解可参考链接&#xff0c;这里的解决方案是将插件里的涉及到Promise.withResolvers的地…

「Py」Python基础篇 之 Python都可以做哪些自动化?

✨博客主页何曾参静谧的博客&#x1f4cc;文章专栏「Py」Python程序设计&#x1f4da;全部专栏「Win」Windows程序设计「IDE」集成开发环境「UG/NX」BlockUI集合「C/C」C/C程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「UG/NX」NX定…

[ 网络安全介绍 5 ] 为什么要学习网络安全?

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

在Java中使用ModelMapper简化Shapefile属性转JavaBean实战

目录 前言 一、原始的处理办法 1、使用Set方法来转换 2、使用构造方法转换 二、基于ModelMapper的动态转换 1、ModelMapper简介 2、集成到项目中 3、Shapefile属性读取 三、总结 前言 在现代软件开发中&#xff0c;尤其是在多层架构中&#xff0c;经常需要将数据从一个…

时间管理的三个痛点

时间管理方面&#xff0c;有三个痛点&#xff1a;不知道、不平衡、不安全。 很多人&#xff0c;忙了一天&#xff0c;感觉很累&#xff0c;但是不知道做了什么。他不知道&#xff0c;这一天工作了几个小时&#xff0c;做了哪些事&#xff0c;分别用了多少时间&#xff0c;只是…

封装el-menu

案例图 数据格式 commonMenu.vue <template><div class"commonMenuStyle"><el-sub-menu v-if"hasChildren" :index"item.MenuId"><template #title><el-icon><location /></el-icon><!-- isColl…