前端工程化面试题 | 18.精选前端工程化高频面试题
🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》
文章目录
- 请解释一下前端中的增量更新和热重载。你熟悉的增量更新工具或热重载工具有哪些?
- 前端中如何处理前后端分离和接口协作?请解释你的实践经验。
- 前后端分离
- 接口协作
- 前端开发中的经验和最佳实践
请解释一下前端中的增量更新和热重载。你熟悉的增量更新工具或热重载工具有哪些?
前端中的增量更新指的是在保持页面状态不变的情况下,更新页面的部分内容。热重载则是指在开发过程中,实时加载更新后的代码,从而提高开发效率。
增量更新在前端领域主要通过以下几种方式实现:
-
使用
window.postMessage
进行跨域通信:通过window.postMessage
方法,可以在父子窗口之间进行跨域通信,从而实现增量更新。 -
使用WebSocket进行实时通信:使用WebSocket进行实时通信,可以在数据发生变化时实时更新页面。
-
使用服务端渲染:使用服务端渲染,将部分静态内容渲染到服务器,从而实现增量更新。
热重载在前端领域主要通过以下几种方式实现:
-
使用
webpack-dev-server
:webpack-dev-server
是一个开发服务器,可以在开发过程中自动加载更新后的代码,从而实现热重载。 -
使用
live-server
:live-server
是一个简单的开发服务器,可以在开发过程中自动加载更新后的代码,从而实现热重载。 -
使用
vue-cli
、create-react-app
等脚手架工具:这些工具在创建项目时已经配置好了开发环境,可以在开发过程中自动加载更新后的代码,从而实现热重载。
常用的增量更新工具和热重载工具:
- 增量更新:
window.postMessage
、WebSocket、服务端渲染等。 - 热重载:
webpack-dev-server
、live-server
、vue-cli
、create-react-app
等。
通过这些工具,可以有效地实现前端中的增量更新和热重载,提高开发效率和用户体验。
前端中如何处理前后端分离和接口协作?请解释你的实践经验。
在前端开发中,前后端分离和接口协作是非常重要的,可以提高开发效率和代码质量。以下是一些实践经验和注意事项:
前后端分离
- 定义接口规范:在前后端分离的项目中,需要定义接口规范,包括接口的URL、请求方法、请求参数、响应数据等。
- 使用
axios
等HTTP客户端库进行接口请求:使用axios
等HTTP客户端库进行接口请求,可以简化接口请求的代码,提高开发效率。 - 接口鉴权:在接口请求中,可以使用
axios
的拦截器等功能,对请求进行鉴权,如添加Token等。
接口协作
- 接口设计:在设计接口时,需要遵循RESTful API规范,如使用GET、POST、PUT、DELETE等HTTP方法表示不同的操作。
- 接口文档:为接口编写详细的文档,包括接口的URL、请求方法、请求参数、响应数据等,方便前后端开发人员理解和使用。
- 接口测试:使用
Postman
等接口测试工具,对接口进行测试,确保接口的正确性和稳定性。 - 代码协作:在前后端分离的项目中,后端提供API接口,前端根据接口规范进行开发,这样可以实现代码的协作和复用。
通过以上实践经验和注意事项,可以有效地实现前后端分离和接口协作,提高开发效率和代码质量。
前端开发中的经验和最佳实践
前端开发中,有一些经验和最佳实践可以帮助我们提高开发效率和代码质量。以下是一些经验:
-
使用模块化编程:将代码按照功能或组件进行模块化,可以提高代码的可维护性和可复用性。可以使用
CommonJS
、AMD
、ES6
模块等模块化编程方式。 -
使用代码编辑器或IDE:使用代码编辑器或IDE(如Visual Studio Code、Sublime Text等),可以提高代码编辑效率,如自动补全、代码格式化、错误检查等。
-
使用构建工具:使用构建工具(如
webpack
、gulp
、grunt
等),可以自动化编译、打包、部署等流程,提高开发效率。 -
使用版本控制工具:使用版本控制工具(如
git
),可以有效地管理代码版本,方便团队协作和代码维护。 -
遵循编码规范:遵循编码规范(如
ESLint
、Airbnb
等),可以提高代码的可读性和可维护性。 -
使用设计模式:在前端开发中,可以使用设计模式(如单例模式、工厂模式、观察者模式等),提高代码的可维护性和可扩展性。
-
进行性能优化:在前端开发中,进行性能优化(如减少HTTP请求、优化CSS和JavaScript代码等),可以提高页面加载速度和性能。
-
进行用户体验优化:在前端开发中,进行用户体验优化(如优化交互效果、提高响应速度等),可以提高用户体验。
-
进行跨平台兼容性处理:在前端开发中,进行跨平台兼容性处理(如使用
@media
查询、使用Modernizr
等),可以提高代码的兼容性。 -
进行测试和优化:在前端开发中,进行测试(如单元测试、集成测试等)和优化(如优化代码结构、减少代码冗余等),可以提高代码质量和稳定性。
以上是一些前端开发中的经验和最佳实践,可以帮助我们提高开发效率和代码质量。
相关文章:

前端工程化面试题 | 18.精选前端工程化高频面试题
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...
大公司的工程师是怎么废掉的...
大家好,我是砖一。 此文作者以嵌入式工程师为基本视角,细说了从初阶到高阶工程师的资质需求,并提示工程师职业道路上的陷阱。可供参考。 一,基础知识 一个嵌入式工程师,很多都是从51单片机或者STM32单片机开始&…...

将yolov8权重文件转为onnx格式并在c#中使用
yolo模型转ONNX 在yolov8中,我们将训练结果的.pt权重文件转换为onnx格式只需要使用ultralytics库中的YOLO类,使用pip安装ultralytics库,然后执行下面python代码 from ultralytics import YOLO# 加载YOLOv8模型 model YOLO("best.pt&q…...
在Spring Boot启动时禁止自动配置数据源相关的组件、@SpringBootApplication
一、SpringBootApplication(exclude {DataSourceAutoConfiguration.class})注解 在Spring Boot启动时禁止自动配置数据源相关的组件。 SpringBootApplication(exclude {DataSourceAutoConfiguration.class})注解的使用案例 这个注解通常应该写在微服务项目的主启动类上&…...
程序人生:不积跬步无以致千里
程序人生 癸卯年冬月,往渭南韩城,拜访司马迁祠。入门攀爬而上,至人有困乏之时,抬头现:高山仰止。归路下山,始现三官洞,遥想西汉时三官洞,出口处刻意再拜别:高山仰止。泪…...

通过二叉树例题深入理解递归问题
目录 引入: 例1:二叉树的前序遍历: 例2: N叉树的前序遍历: 例3:二叉树的最大深度: 例4:二叉树的最小深度 例5:N叉树的最大深度: 例6:左叶子…...
【Android 协程常见用法】
我们这里只讲解一下,协程在Android项目中常见用法,原理知识不在进行说明了。 依赖 lifecycleScope只能在Activity、Fragment中使用,会绑定Activity和Fragment的生命周期。依赖库: implementation androidx.lifecycle:lifecycle…...

python 进程笔记一 (概念+示例代码)
1. 进程的概念 进程是资源分配的最小单位,也是线程的容器,线程(python 线程 (概念示例代码))是CPU调度的基本单位,一个进程包括多个线程。 程序:例如xxx.py是一个程序 进程…...
各中间件数据库默认访问端口总结
说明 在生态丰富的开发环境下,我们常常需要接触很多中间件产品,中间件默认的连接端口以及可视化ui访问端口也时不时的需要用到,这里循序渐进做好登记,以备查阅! 中间件/数据库名称默认端口管理台端口默认账号密码rabbi…...

鲲鹏arm64架构下安装KubeSphere
鲲鹏arm64架构下安装KubeSphere 官方参考文档: https://kubesphere.io/zh/docs/quick-start/minimal-kubesphere-on-k8s/ 在Kubernetes基础上最小化安装 KubeSphere 前提条件 官方参考文档: https://kubesphere.io/zh/docs/installing-on-kubernetes/introduction/prerequi…...
python 函数-02-返回值注释格式
01 函数返回值 1)python中函数可以没有返回值,也可以有通过return的方式 – 【特殊性,区别于java c#等】 2)返回值可以是一个或者多个,多个时通过逗号隔开 – 【特殊性,区别于java c#等】 3)多…...

【前端素材】推荐优质后台管理系统Upcube平台模板(附源码)
一、需求分析 后台管理系统在多个层次上提供了丰富的功能和细致的管理手段,帮助管理员轻松管理和控制系统的各个方面。其灵活性和可扩展性使得后台管理系统成为各种网站、应用程序和系统不可或缺的管理工具。 当我们从多个层次来详细分析后台管理系统时࿰…...

可视化 RAG 数据 — 用于检索增强生成的 EDA
原文地址:Visualize your RAG Data — EDA for Retrieval-Augmented Generation 2024 年 2 月 8 日 Github:https://github.com/Renumics/rag-demo/blob/main/notebooks/visualize_rag_tutorial.ipynb 为探索Spotlight中的数据,我们使用Pa…...

数学建模论文、代码百度网盘链接
1.[2018中国大数据年终总决赛冠军] 金融市场板块划分与轮动规律挖掘与可视化问题 2.[2019第九届MathorCup数模二等奖] 数据驱动的城市轨道交通网络优化策略 3.[2019电工杯一等奖] 露天停车场停车位的优化设计 4.[2019数学中国网络数模一等奖] 基于机器学习的保险业数字化变革…...
mysql 迁移-data目录拷贝方式
背景:从服务器进水坏掉,50多G的数据库要重新做主从,但以导入导出的方式太慢,简直是灾难性的,一夜都没好,只好想到了拷贝mysql数据文件的方式 拷贝的数据文件的前提 1.数据库版本必需一致(可以…...

学习 LangChain 的 Passing data through
学习 LangChain 的 Passing data through 1. Passing data through2. 示例 1. Passing data through RunnablePassthrough 允许不改变或添加额外的键来传递输入。这通常与 RunnableParallel 结合使用,将数据分配给映射中的新键。 RunnablePassthrough() 单独调用&…...

C# OpenVINO PaddleSeg实时人像抠图PP-MattingV2
目录 效果 项目 代码 下载 C# OpenVINO 百度PaddleSeg实时人像抠图PP-MattingV2 效果 项目 代码 using OpenCvSharp; using Sdcb.OpenVINO; using System; using System.Diagnostics; using System.Drawing; using System.Security.Cryptography; using System.Text; us…...
【Android 11】AOSP Settings WIFI随机MAC地址功能
AOSP Settings WIFI随机MAC地址功能 背景 最近客户提出了想要实现随机WIFIMAC地址的功能(我们默认WIFI的MAC地址是固定的)。网上搜到了一篇不错的文章,本次改动也是基于这个来写的。 由于客户指定使用的settings是AOSP的,所以在…...

dmrman备份还原
脱机还原工具-dmrman 前言 根据达梦官网文档整理 一、概述 DMRMAN 命令行设置参数执行又可分为命令行指定脚本、命令行指定语句两种执行方式。 指定语句 $ DMRMAN RMAN>BACKUP DATABASE/dmdata/data/DAMENG/dm.ini;指定脚本 创建一个名为 cmd_file.txt 的文件&#x…...

网页403错误(Spring Security报异常 Encoded password does not look like BCrypt)
这个错误通常表现为"403 Forbidden"或"HTTP Status 403",它指的是访问资源被服务器理解但拒绝授权。换句话说,服务器可以理解你请求看到的页面,但它拒绝给你权限。 也就是说很可能测试给定的参数有问题,后端…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...
【Linux】shell脚本忽略错误继续执行
在 shell 脚本中,可以使用 set -e 命令来设置脚本在遇到错误时退出执行。如果你希望脚本忽略错误并继续执行,可以在脚本开头添加 set e 命令来取消该设置。 举例1 #!/bin/bash# 取消 set -e 的设置 set e# 执行命令,并忽略错误 rm somefile…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真
目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销,平衡网络负载,延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...

UE5 学习系列(三)创建和移动物体
这篇博客是该系列的第三篇,是在之前两篇博客的基础上展开,主要介绍如何在操作界面中创建和拖动物体,这篇博客跟随的视频链接如下: B 站视频:s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...

HTML 列表、表格、表单
1 列表标签 作用:布局内容排列整齐的区域 列表分类:无序列表、有序列表、定义列表。 例如: 1.1 无序列表 标签:ul 嵌套 li,ul是无序列表,li是列表条目。 注意事项: ul 标签里面只能包裹 li…...

srs linux
下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935,SRS管理页面端口是8080,可…...

论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)
笔记整理:刘治强,浙江大学硕士生,研究方向为知识图谱表示学习,大语言模型 论文链接:http://arxiv.org/abs/2407.16127 发表会议:ISWC 2024 1. 动机 传统的知识图谱补全(KGC)模型通过…...
【AI学习】三、AI算法中的向量
在人工智能(AI)算法中,向量(Vector)是一种将现实世界中的数据(如图像、文本、音频等)转化为计算机可处理的数值型特征表示的工具。它是连接人类认知(如语义、视觉特征)与…...
Unit 1 深度强化学习简介
Deep RL Course ——Unit 1 Introduction 从理论和实践层面深入学习深度强化学习。学会使用知名的深度强化学习库,例如 Stable Baselines3、RL Baselines3 Zoo、Sample Factory 和 CleanRL。在独特的环境中训练智能体,比如 SnowballFight、Huggy the Do…...

全志A40i android7.1 调试信息打印串口由uart0改为uart3
一,概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本:2014.07; Kernel版本:Linux-3.10; 二,Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01),并让boo…...