乐闻世界logo
搜索文章和话题
主页文章专栏面试题问题

TA的文章

查看更多
基于React创建重叠头像组件,深入理解CSS重叠样式

基于React创建重叠头像组件,深入理解CSS重叠样式

最近项目有个新需求,需要把用户的头像水平排列并且重叠。本来以为挺麻烦的,刚开始还想着要用JS去计算每一个头像需要位移的距离。其实这个需求只需要一行代码就能搞定。最终的效果图如下:效果图实现方案首先定义HTML代码结构importReactfrom"react";import"./index.less";constavatars=["<https://upload.jianshu.io/u
Cypress 如何调试测试案例代码?

Cypress 如何调试测试案例代码?

Cypress提供了一套易用的API,让你可以快速编写出可读性强、维护性好的测试代码。但是,无论是多么优秀的测试代码,也难免会遇到需要调试的时刻。本文将通过一种通俗易懂的方式,教你如何在Cypress中调试代码,以确保你的测试能够顺利进行。调试方式1.使用Cypress自带的调试命令Cypress提供了一个.debug()命令,可以帮助你在测试运行时暂停,这样你就可以使用浏览器的开发者工具来检查
JS如何生成随机颜色,并基于React封装随机颜色选择器组件

JS如何生成随机颜色,并基于React封装随机颜色选择器组件

在标签功能中,由于有「背景色」属性,每次新增标签时都为选择哪种颜色犯难。因此,我们思考如何通过JS代码生成随机颜色,提取一个通用的随机颜色生成工具,并基于React框架封装随机颜色选择器组件。实际效果原理与思路作为前端开发人员,我们知道HTML接受RGB、HEX、HSL三种格式的颜色。虽然是不同的格式,但是它们的本质都是通过数字表达出颜色。因为RGB、HEX、HSL本身都是数字,那么通过生成
JSONP 如何帮助我们解决跨域问题以及如何自己实现JSONP

JSONP 如何帮助我们解决跨域问题以及如何自己实现JSONP

什么是JSONP?JSONP(JSONwithPadding)是一种技术策略,其能够克服Web应用程序中的跨域数据访问限制。为了理解JSONP,我们需要先理解什么是跨域。由于浏览器的同源策略,JavaScript只能获取和操作与其同源(即域名、协议和端口都相同)的数据。但在实际开发中,我们经常需要向不同的源请求数据,这就产生了跨域问题。JSONP主要是通过动态<script>来进行跨域
如何在 NestJS 中的优雅管理 Session

如何在 NestJS 中的优雅管理 Session

在Web开发中,Session是一个核心概念,它用于在多个请求之间保存和共享用户数据。NestJS作为一个高度模块化的Node.js框架,为处理HTTPSession提供了多种方案。在本教程中,我们将详细探讨如何在NestJS中处理Session,并提供一个简单的示例来引导您完成基本的Session管理。NestJSSession管理步骤NestJS没有内置的Session管理,但它与Expres
React 支持多语言国际化 -- i18next

React 支持多语言国际化 -- i18next

前言如果我们的项目需要更多的流量,支持其他国家的语言是必不可少的。对于React项目我们该如何实现项目多语言,让工程走向国际化,本文将介绍目前最通用的解决方案i18next。准确是说i18n并不仅仅是为React而生,为了支持React项目,我们还需要引入react-i18next插件。本文将通过简单的例子解释i18next的核心功能,下图是最终效果。
从上到下按层打印二叉树

从上到下按层打印二叉树

从上到下按层打印二叉树问题解决方案BFS广度遍历/***Definitionforabinarytreenode.*functionTreeNode(val){*this.val=val;*this.left=this.right=null;*}*//***@param{TreeNode}root*@return{number[][]}*/varlevelOrder=function(root){
vscode node开发调试断点配置 launch.json

vscode node开发调试断点配置 launch.json

对于开发者来讲,怎么科学合理的进行程序调试是至关重要的。调试工具可以协助开发者清晰的看到程序的走向以及程序每一步执行的详细信息。开发前端项目,比如React,vue等,开发者可以直接在代码中插入debugger进行调试。Node程序调试,我们可以借助开发工具vscode提供的能力进行操作。调试配置选择调试选项,createalunch.jsonfile选择需要调试的环境,以Node程序调试系统
一篇文章学会如何使用 NestJS 的五种 Provider 提供者

一篇文章学会如何使用 NestJS 的五种 Provider 提供者

在构建复杂的后端应用中,如何有效地管理和彼此协作的各个部分,以及如何共享和复用功能已成为开发者们重要关注的问题。覆盖这些需求的一种技术就是NestJS中的Providers。这次,让我们一起深入探讨这个关键概念,解密Providers的奥秘,了解它们是如何提供和分配服务的。在这篇文章中,我们将学习五种主要的Provider类型:值提供者、类提供者、工厂提供者、异步工厂提供者和别名提供者,以及如何在
「自己动手丰衣足食」搭建React脚手架

「自己动手丰衣足食」搭建React脚手架

前言刚开始学习React的朋友基本都是从Facebook官方提供create-react-app脚手架开始,别人的脚手架开箱即用固然爽,但是有的时候想要进行一些功能的拓展(集成less等)就需要去百度谷歌。因为脚手架把整个项目的编译构建过程高度集成了,我们想通过脚手架生成的代码学习项目工程化,刚开始肯定是大难度的。伟人曾道:自己动手,丰衣足食。为了更深层次的去学习react,去尝试理解react项
CDN 了解一下

CDN 了解一下

「为啥咱们的网站访问那么慢」「网站加载这么慢客户都跑了」「能不能把咱们的网站加载速度提升下」本文记录的内容「CDN」是解决上面问题的方法之一,也是技术难度,成本相对较低的一种方式。「问题起源」首先分析一下网站加载速度慢的原因(问题基于前端静态文件部署在普通的云服务器CVM上,没有设置其他任何优化措施的情况)浏览器渲染页面需要在请求到需要渲染的html文件的情况下,然后解析html中的等需要加载其他
「数据结构」树的遍历

「数据结构」树的遍历

functiondfs(root){//dosthdfs(root.left);dfs(root.right);}functiondfs(root){dfs(root.left);//dosthdfs(root.right);}functiondfs(root){dfs(root.left);dfs(root.right);//dosth}...
通俗理解this指向问题以及实现call、apply、bind

通俗理解this指向问题以及实现call、apply、bind

电话面试的时候,面试官让我口述对this的理解,以及如何修改this的指向。本来是很常见也相对比较简单的问题,但是在口述如何手写call方法的时候,却回答的磕巴,感觉还是没有真正的理解本质,借这篇文章好好理一下思路在JavaScript中,this是一个特殊的关键字,用于指代当前执行上下文中的对象。它的指向问题是前端开发中经常遇到的一个难点。同时,[JavaScript]()中提供了call、
Node 通过 http 协议上传文件到服务器

Node 通过 http 协议上传文件到服务器

前言:web端上传图片、文件等流化数据,一般使用form表单方式,或者通过Ajax方式上传时就使用FormData来承载流化数据。具体可以参考AJAX图片上传功能实现(点击,拖拽,粘贴)Koa服务端同时也存在需要使用Node操作方式上传文件到http服务器上,下文详细记载。一、requestnode端添加request依赖库npminstallrequest文件上传操作constpath=requ
基于 NestJS 操作 TypeORM 中的一对多 OneToMany

基于 NestJS 操作 TypeORM 中的一对多 OneToMany

TypeORM是一个在TypeScript和JavaScript(ES7,ES6,ES5)中提供了许多开箱即用特性的ORM,它能够改善我们处理数据库操作的效率与可维护性。在复杂的应用开发过程中,数据间的关系处理显得尤其重要。今天我们将在NestJS中探索TypeORM的OneToMany(一对多)关系,这是一种常见且强大的数据模型关系。在建立应用程序时,我们通常需要处理大量的增删查改(CRUD)操
基于 NestJS 操作 TypeORM 中的多对多 ManyToMany

基于 NestJS 操作 TypeORM 中的多对多 ManyToMany

TypeORM是一个在TypeScript和JavaScript(ES7,ES6,ES5)中提供了许多开箱即用特性的ORM,它能够改善我们处理数据库操作的效率与可维护性。在复杂的应用开发过程中,数据间的关系处理显得尤其重要。今天我们将在NestJS中探索TypeORM的ManyToMany(多对多)关系,这是一种常见且强大的数据模型关系。在建立应用程序时,我们通常需要处理大量的增删查改(CRUD)
一篇文章学会如何使用 NestJS 的 Guards 守卫实现系统身份验证和授权

一篇文章学会如何使用 NestJS 的 Guards 守卫实现系统身份验证和授权

当我们基于NestJS框架构建和管理应用程序时,为了保障其安全性,我们常常需要对某些敏感操作或敏感信息的访问进行限制,这是我们需要使用到守卫的地方。它作为一种可以阻止未经授权的访问的机制,对我们的应用程序起到了守护的作用。在这篇文章中,我将深入剖析NestJS的守卫,以帮您全面了解这个概念。我会从解释其背后的工作机制开始,接着介绍使用守卫的各种场景,并以详细的示例来演示如何在NestJS项目中实现
 Webpack 面试题汇总

Webpack 面试题汇总

什么是前端模块化?AMD、CMD、CommonJS、ES6模块化之间的区别是什么?模块化是指将一个复杂的系统分解为多个模块以方便编码。模块化规范的实现是为了达成浏览器端模块化的目的。AMD是一种Javascript模块化规范,采用异步的方式去加载依赖的模块。不用转换代码的情况下直接运行在浏览器环境。依赖前置,提前执行。代表库requirejsCMD是一种Javascript模块化规范,依赖就近
npm 工具集汇总

npm 工具集汇总

NPM工具集汇总Node包名说明KoaKoa-routerKoa-statickoa-static-cachekoa-bodyparserkoa-bodykoa-sendKoa-viewkoa-compress压缩koa-etag协商缓存koa-conditional-get协商缓存koa-helmet头盔;防护帽,加强服务端防御koa-csrfCsrfKoa-corsCorskoa-sessio
如何使用 Scrcpy 从手机传输文件至电脑

如何使用 Scrcpy 从手机传输文件至电脑

Scrcpy是一个非常有用的开源工具,它允许用户通过USB或Wi-Fi连接在电脑上控制和显示Android设备的屏幕。除了远程控制手机外,Scrcpy也可以用来从手机传输文件到电脑。以下是你可以遵循的步骤,轻松实现文件传输。1.通过分享面板实现步骤一、安装Scrcpy首先,你需要在你的电脑上安装Scrcpy。Scrcpy可以在多种操作系统上运行,包括Windows、macOS和Linux。Win

TA的教程专栏

查看更多
Cypress 通关指南

Cypress 通关指南

项目的稳定性是项目迭代过程中最重要的关注点,在Web应用开发中,如何保证程序的高质量,可靠和良好的用户体验是指关重要的。为了达到这些目标,E2E自动化测试是不可或缺的环节。 目前市面上流行的E2E自动化框架中,cypress是基于JavaScript编写用例的框架,作为前端开发者,可以轻松接入E2E自动化测试。 Cypress为开发者提供了简洁、高效的测试方法,无论是对于初学者还是经验丰富的开发者,都能迅速上手。 本教程将详细的介绍Cypress的用例编写技巧和进阶用法。
Eslint 使用指南

Eslint 使用指南

代码质量对于任何规模的前端项目都是至关重要的一环。通过本系列教程,你将学习如何利用 Eslint —— 一个强大的 JavaScript 代码检查工具 —— 来提升代码的一致性和避免常见错误。 本教程将引导你从 Eslint 的基础知识开始,详细了解其配置过程、内置规则以及插件系统。如何为项目定制规则集,以满足特定编码标准和风格指南的需求。同时,也会学习到如何集成 Eslint 到现代前端工作流中,包括与代码编辑器、构建系统和持续集成/持续部署(CI/CD)环境的融合。 针对不同的前端框架和库,如 React、Vue、TypeScript 等,提供专门的指导和最佳实践,确保你能在各种开发场景下充分利用 Eslint。此外,教程也会讨论如何处理 Eslint 报告的问题,以及如何与团队成员合作,共同推广代码质量标准。
Recoil 使用指南

Recoil 使用指南

随着复杂前端应用的兴起,传统的状态管理解决方案面临诸多挑战。Recoil 是为 React 应用量身定制的状态管理库,本系列教程旨在通过通俗易懂的语言和丰富的实例,带领开发者从基础概念入手,进一步掌握 Recoil 的核心 API、原理、以及与 React 的天然集成。 本教程将讨论 Recoil 的关键特性,如原子(atom)、选择器(selector)、以及其他高级功能,逐步展示如何利用 Recoil 构建高效、可维护的状态管理体系。此外,教程还会涵盖性能优化、测试策略、以及常见问题和解决方案,确保你能够在实际项目中灵活运用 Recoil。
Typeorm 使用指南

Typeorm 使用指南

TypeORM 是一个流行的 TypeScript ORM(对象关系映射)库,它可以帮助您轻松地将 TypeScript 类映射到关系型数据库表。本教程将帮助您深入了解 TypeORM 的高级功能和技术,以帮助您更好地利用这个强大的库。 在本教程中,您将学习到: 如何使用 TypeORM 中的高级查询和过滤功能来查询和操作数据库; 如何使用 TypeORM 中的实体继承和关系映射来创建复杂的数据模型; 如何使用 TypeORM 中的迁移和数据填充来管理数据库模式和数据; 如何在 TypeORM 中使用存储过程和触发器来扩展数据库功能; 如何在 TypeORM 中使用多数据库和分布式事务来管理复杂的应用程序。 本教程适合那些已经有一定 TypeORM 开发经验,并想要深入了解其高级功能和技术的开发人员。无论您是初学者还是有一定经验的 TypeORM 开发人员,本教程都将为您提供宝贵的学习资源和实践经验。 让我们开始您的 TypeORM 进阶之旅吧!
Git 最佳使用指南

Git 最佳使用指南

在现代软件开发中,版本控制系统是不可或缺的工具,而Git是其中最流行的选择。这本《Git战胜指南》是为希望精通Git的开发者而设计的,包含从基础概念到高级技巧的全面介绍。我们将从Git的安装和基础配置开始,指导你通过实践学习如何进行提交(commit)、分支(branch)、合并(merge)和冲突解决。进阶章节将涵盖更复杂的主题,如分支策略、远程仓库管理、标签、钩子(hooks)和子模块(submodules)。此外,本手册还包括日常工作流程中的最佳实践和常见问题解决方案,以及如何使用Git来提高团队协作的效率。 通过这个通关指南,你将能够自信地使用Git来管理复杂的开发项目,并将其作为你软件开发技能集的一部分。
React 入门宝典

React 入门宝典

React 是一个流行的 JavaScript 库,用于构建大规模、高性能的 Web 应用程序。本教程将帮助您从 React 的基础知识入门开始,逐步深入掌握 React 的高级概念和技术,以成为一名优秀的 React 开发人员。 在本教程中,您将学习到: React 的基础概念和核心原则,如组件、Props、State、生命周期等; 如何使用 JSX 语法编写 React 组件和模板; 如何使用 React 的事件处理、表单处理、样式管理等功能; 如何使用 React Router 实现单页应用程序; 如何使用 Redux 进行状态管理和数据流控制; 如何使用 React 的高级技术,如 Hooks、Context、Portal 等。 本教程适合那些已经有一定 JavaScript 编程经验,并希望进一步学习 React 技术的开发人员。无论您是初学者还是有一定经验的 React 开发人员,本教程都将为您提供宝贵的学习资源和实践经验。 让我们开始您的 React 之旅吧!
Nextjs 全栈开发手册

Nextjs 全栈开发手册

在这个系列教程中,您将踏上一段探索 Next.js 的精彩旅程。Next.js 是一款基于 Node.js 和 React 的现代化框架,专为构建快速、静态生成和服务器端渲染的Web应用而设计。无论您是前端新手还是经验丰富的开发者,本教程都将以步骤分解的方式带领您从基础概念到高级功能,全面了解 Next.js 的核心特性。 我们将从 Next.js 的安装和基本配置开始,逐步深入到路由、状态管理、构建优化以及部署策略。通过实际案例,您将学会如何利用 Next.js 提升开发效率,提高应用性能,并构建出具有优秀SEO表现和用户体验的Web应用。 随着本系列教程的深入,您将掌握 Next.js 最佳实践,与此同时,我们还将涵盖如何整合RESTful API和GraphQL、使用静态站点生成(SSG)与服务器端渲染(SSR)的先进技术,以及如何借助 Vercel 等平台,实现无缝的生产部署。 让我们一起开启这次学习之旅,探索 Next.js 带来的无限可能,为您的前端技能树添上一笔重要的一笔。
Mongoose 使用指南

Mongoose 使用指南

在本教程中,我们将逐步探索Mongoose——一个在Node.js环境下与MongoDB数据库协同工作的强大库。从基本概念的铺垫到实用技巧的深度剖析,本系列覆盖了Schema设计、数据类型定义、模型创建、查询优化、插件扩展等核心主题。你将学习如何利用Mongoose的Schema来定义数据结构,实现数据验证和类型转换,以及如何通过模型进行数据的增删改查操作。 此外,教程将深入Mongoose的高级特性,包括但不限于索引管理、聚合框架、事务处理和数据迁移。我们将通过丰富的示例和练习,教你如何运用Mongoose来处理复杂查询、关联数据以及性能调优。 随后,本系列教程将深入讨论更高级的特性,如中间件(pre和post hooks)、数据校验、虚拟属性和实例方法,以及如何使用聚合管道进行复杂查询。此外,我们将详细介绍如何处理关系型数据,在Mongoose中实现文档的嵌入和引用,以及如何优雅地处理这些关系。 为了将理论与实践相结合,每一部分内容都包含了逐步的代码示例和实战小项目,帮助你更好地理解和运用Mongoose的功能。我们还会讨论性能调优、错误处理和最佳实践,以确保你能够构建既健壮又高效的Node.js应用。
TailwindCSS 使用指南

TailwindCSS 使用指南

Tailwind CSS 是一个流行的 CSS 工具库,它提供了一系列预定义的 CSS 类,可以帮助您轻松地创建漂亮的用户界面。本教程将帮助您深入了解 Tailwind CSS 的高级功能和技术,以帮助您更好地利用这个强大的工具库。 在本教程中,您将学习到: 如何使用 Tailwind CSS 的主题和变量来自定义外观和样式; 如何在 Tailwind CSS 中配置和使用插件来扩展其功能; 如何在 Tailwind CSS 中使用 JS 钩子和样式函数来创建动态样式; 如何在 Tailwind CSS 中创建响应式布局和样式; 如何在 Tailwind CSS 中使用 PurgeCSS 来优化和精简 CSS。 本教程适合那些已经有一定 Tailwind CSS 开发经验,并想要深入了解其高级功能和技术的开发人员。无论您是初学者还是有一定经验的 Tailwind CSS 开发人员,本教程都将为您提供宝贵的学习资源和实践经验。 让我们开始您的 Tailwind CSS 进阶之旅吧!
Koa.js 学习手册

Koa.js 学习手册

这是一系列为前端开发者量身打造的综合指南,旨在帮助你从基础到高级,全面掌握Koa框架。我们将通过实战案例、核心概念剖析以及最佳实践分享,带你一步步深入了解Koa的运作原理和优雅的API设计。 无论你是初学者还是希望扩展你的Node.js知识库的资深开发者,这个系列教程都将是你不可或缺的资源。我们将从Koa的安装与构建开始,逐渐深入到中间件的使用、路由管理、异常处理和性能优化等高级话题,确保你能在Web开发的实战中运用Koa进行高效、模块化的开发。

TA的问题

查看更多

TA的面试题

查看更多
个人成就
  • 获得 0 次点赞
  • 内容获得 0 次评论
  • 获得 0 次收藏