【每日前端面经】2023-02-27
题目来源: 牛客
CSS盒模型
CSS中的盒子包括margin|border|padding|content四个部分,对于标准盒子模型(content-box)的width=content,但是对于IE盒子模型(border-box)的width=content+border2+padding2
CSS选择器
- 标签选择器
- 类选择器
- ID选择器
- 参数选择器
- 通用选择器
- 组合选择器
- 子代选择器
- 后代选择器
- 兄弟选择器
- 相邻兄弟选择器
- 列表选择器
- 伪类选择器
- 伪元素选择器
JS数据类型
- Number
- String
- Object
- Undefined
- Null
- Boolean
- Symbol
- BigInt
Webpack打包的理解、性能优化
本质上,webpack是一个现代JavaScript应用程序的静态模块打包器。当Webpack处理应用程序时,会递归的构建一个依赖关系图,其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个bundle
- 提升基础环境版本
- 使用include/exclude避免重复打包
- 合理利用缓存
- 合理使用plugin
- 合理配置resolve
- 启用多进程打包
- 开发中使用热更新替换自动刷新
- 使用DIIPlugin插件优化时间
前端性能优化
- 浏览器
- 减少HTTP请求
- 使用HTTP2.0
- 设置浏览器缓存
- 白屏做加载动画
- 资源
- 静态资源CDN
- 静态资源单独域名
- GZIP压缩
- 做服务端渲染
- 头部放置CSS,底部放置JS
- 图片
- 字体图标代替图片图标
- 精灵图
- 图片懒加载
- 图片预加载
- 使用PNG格式的图片
- 图片转BASE64格式
- 代码
- 慎用全局变量
- 缓存全局变量
- 减少回流与重绘
- 节流防抖
- 少用闭包
- 减少数据读取次数
- 文档碎片优化节点
- 减少判断层级
- 字面量与构造式
- 项目
- 长列表优化
- web worker
- 避免iframe
- 打包
- 减少代码体积
- 按需加载
- 提取第三方库代码
- webpack dll优化
Vue2和Vue3的区别
- 生命周期
- 多根节点
- 组合式API
- 异步组件
- Teleport: 可以将部分DOM移动到APP之外的位置
- 响应式原理: Vue2的原理是Object.defineProperty;Vue3的原理是Proxy/Reflect
- 虚拟DOM: 新增patchFlag字段,优化渲染
- 事件缓存
- Diff算法优化
- 打包优化: 新增Tree-shaking
- TypeScript支持
Vue-Router的原理
路由描述的是URL与UI之间的映射关系,这种隐射是单向的,即URL变化引起UI变化(无需刷新页面)
- hash模式: 通过hashchange事件监听URL的变化
- history模式: 拦截pushState/replaceState的调用和标签的点击事件监听URL的变化
开发中遇到错误怎么排查
css盒模型(css的两种盒模型:标准盒模型、怪异盒模型)和 css3指定盒子模型种类的box-sizing属性
深入浅出vue-router原理
CSS 3 所有的选择器整理(2023.2)
判断Vue3与Vue2的区别
web前端性能优化(全汇总)
webpack 打包原理及流程解析,超详细!
相关文章:
【每日前端面经】2023-02-27
题目来源: 牛客 CSS盒模型 CSS中的盒子包括margin|border|padding|content四个部分,对于标准盒子模型(content-box)的widthcontent,但是对于IE盒子模型(border-box)的widthcontentborder2padding2 CSS选…...
springboot + easyRules 搭建规则引擎服务
依赖 <dependency><groupId>org.jeasy</groupId><artifactId>easy-rules-core</artifactId><version>4.0.0</version></dependency><dependency><groupId>org.jeasy</groupId><artifactId>easy-rules…...
Mac电脑配置环境变量
1.打开配置文件bash_profile open -e .bash_profile 2.如果没有创建过.bash_profile,则先需要创建 touch .bash_profile 3.输入你要配置的环境变量 #Setting PATH for Android ADB Tools export ANDROID_HOME/Users/xxx/android export PATH${PATH}:${ANDROID_HOME}…...
Windows系统x86机器安装(麒麟、统信)ARM系统详细教程
本次介绍在window系统x86机器上安装国产系统 arm 系统的详细教程。 注:ubuntu 的arm系统安装是一样的流程。 1.安装环境准备。 首先,你得有台电脑,配置别太差,至少4核8G内存,安装window10或者11都行(为啥…...
消息中间件篇之RabbitMQ-高可用机制
一、怎么保证高可用性 在生产环境下,使用集群来保证高可用性,一般我们采用普通集群、镜像集群、仲裁队列。 二、普通集群 普通集群,或者叫标准集群(classic cluster),具备下列特征: 1. 会在集…...
express+mysql+vue,从零搭建一个商城管理系统5--用户注册
提示:学习express,搭建管理系统 文章目录 前言一、新建user表二、安装bcryptjs、MD5、body-parser三、修改config/db.js四、新建config/bcrypt.js五、新建models文件夹和models/user.js五、index.js引入使用body-parser六、修改routes/user.js七、启动项…...
canvas水波纹效果,jquery鼠标水波纹插件
canvas水波纹效果,jquery鼠标水波纹插件 效果展示 jQuery水波纹效果,canvas水波纹插件 HTML代码片段 <div class"scroll04wrap"><h3>发展历程</h3><div class"scroll04"><p>不要回头,一…...
Zookeeper客户端命令、JAVA API、监听原理、写数据原理以及案例
1. Zookeeper节点信息 指定服务端,启动客户端命令: bin/zkCli.sh -server 服务端主机名:端口号 1)ls / 查看根节点下面的子节点 ls -s / 查看根节点下面的子节点以及根节点详细信息 其中,cZxid是创建节点的事务id,…...
[嵌入式系统-34]:RT-Thread -19- 新手指南:RT-Thread标准版系统架构
目录 一、RT-Thread 简介 二、RT-Thread 概述 三、许可协议 四、RT-Thread 的架构 4.1 内核层: 4.2 组件与服务层: 4.3 RT-Thread 软件包: 一、RT-Thread 简介 作为一名 RTOS 的初学者,也许你对 RT-Thread 还比较陌生。然…...
postman访问k8s api
第一种方式: kubectl -n kubesphere-system get sa kubesphere -oyaml apiVersion: v1 kind: ServiceAccount metadata:annotations:meta.helm.sh/release-name: ks-coremeta.helm.sh/release-namespace: kubesphere-systemcreationTimestamp: "2023-07-24T07…...
UE4c++ ConvertActorsToStaticMesh
UE4c ConvertActorsToStaticMesh ConvertActorsToStaticMesh UE4c ConvertActorsToStaticMesh创建Edior模块(最好是放Editor模块毕竟是编辑器代码)创建UBlueprintFunctionLibraryUTestFunctionLibrary.hUTestFunctionLibrary.cpp:.Build.cs 目标:为了大量…...
Qt中tableView控件的使用
tableView使用注意事项 tableView在使用时,从工具栏拖动到底层页面后,右键进行选择如下图所示: 此处需要注意的是,需要去修改属性,从UI上修改属性如下所示: 也可以通过代码修改属性: //将其设…...
【医学影像】LIDC-IDRI数据集的无痛制作
LIDC-IDRI数据集制作 0.下载0.0 链接汇总0.1 步骤 1.合成CT图reference 0.下载 0.0 链接汇总 LIDC-IDRI官方网址:https://www.cancerimagingarchive.net/nbia-search/?CollectionCriteriaLIDC-IDRINBIA Data Retriever 下载链接:https://wiki.canceri…...
MacOS开发环境搭建详解
搭建MacOS开发环境需要准备相应的软硬件,并遵循一系列步骤。以下是详细的步骤: 软硬件准备: MacOS电脑:确保你的电脑运行的是MacOS操作系统。Xcode软件:打开AppStore,搜索并安装Xcode。安装过程可能较长&…...
全量知识系统问题及SmartChat给出的答复 之2
Q6. 根据DDD的思想( 也就是借助 DDD的某个或某些实现),是否能按照这个想法给出程序设计和代码结构? 当使用领域驱动设计(DDD)的思想来设计程序和代码结构时,可以根据领域模型、领域服务、值对象、实体等概念来进行设计…...
嵌入式驱动学习第一周——vim的使用
前言 本篇博客学习使用vim,vim作为linux下的编辑器,学linux肯定是绕不开vim的,因为不确定对方环境中是否安装了编译器,但一定会有vim。 对于基本的使用只需要会打开文件,保存文件,编辑文件即可。 嵌入式驱动…...
loop_list单向循环列表
#include "loop_list.h" //创建单向循环链表 loop_p create_head() { loop_p L(loop_p)malloc(sizeof(loop_list)); if(LNULL) { printf("create fail\n"); return NULL; } L->len 0; L->nextL; retur…...
Python爬虫实战第二例【二】
零.前言: 本文章借鉴:Python爬虫实战(五):根据关键字爬取某度图片批量下载到本地(附上完整源码)_python爬虫下载图片-CSDN博客 大佬的文章里面有API的获取,在这里我就不赘述了。 一…...
Eclipse是如何创建web project项目的?
前面几篇描述先后描述了tomcat的目录结构和访问机制,以及Eclipse的项目类型和怎么调用jar包,还有java的main函数等,这些是一些基础问题,基础高清出来才更容易搞清楚后面要说的东西,也就是需求带动学习,后面…...
Excel的中高级用法
单元格格式,根据数值的正负分配不同的颜色和↑ ↓ 根据数值正负分配颜色 2-7 [蓝色]#,##0;[红色]-#,##0 分配颜色的基础上,根据正负加↑和↓ 2↑-7↓ 其实就是在上面颜色的代码基础上加个 向上的符号↑,或向下的符号↓ [蓝色]#,##0↑;[红色…...
Qwen3.5-2B低门槛部署指南:无Linux经验用户也能完成的5步流程
Qwen3.5-2B低门槛部署指南:无Linux经验用户也能完成的5步流程 1. 为什么选择Qwen3.5-2B Qwen3.5-2B是阿里云推出的轻量化多模态基础模型,属于Qwen3.5系列的小参数版本(20亿参数)。这个模型特别适合想要尝试AI能力但又担心硬件配…...
Xftp 7免费版隐藏功能大揭秘:从图像预览到OpenSSH证书认证,不止是传文件
Xftp 7进阶实战:解锁专业用户都在用的高效文件管理技巧 每次在服务器间来回传输日志文件时,我总忍不住想起第一次用Xftp 7的场景——那时我只把它当作普通FTP工具,直到偶然发现它的图像预览功能,才意识到自己错过了多少效率神器。…...
从浏览器到桌面:3步将你的Twine游戏变成专业桌面应用 [特殊字符]
从浏览器到桌面:3步将你的Twine游戏变成专业桌面应用 🚀 【免费下载链接】twine-app-builder Automatically generate Windows and macOS versions of your Twine games, for free! 项目地址: https://gitcode.com/gh_mirrors/tw/twine-app-builder …...
SOCD Cleaner:终极键盘优化工具 - 5个关键优势提升游戏操作精度
SOCD Cleaner:终极键盘优化工具 - 5个关键优势提升游戏操作精度 【免费下载链接】socd Key remapper for epic gamers 项目地址: https://gitcode.com/gh_mirrors/so/socd 在竞技游戏的微秒级对决中,你是否曾因同时按下W和S键导致角色卡顿&#x…...
imFile下载管理器深度解析:为什么它能成为你的全能下载解决方案?
imFile下载管理器深度解析:为什么它能成为你的全能下载解决方案? 【免费下载链接】imfile-desktop A full-featured download manager. 项目地址: https://gitcode.com/gh_mirrors/im/imfile-desktop 你是否曾经为下载大型文件而烦恼?…...
别再傻傻分不清了!SDN南向接口和南向协议到底有啥区别?
解码SDN南向通信:从接口概念到协议实战的深度解析 想象一下你刚搬进一套智能家居系统,墙上布满各种插座(接口),而你的电器设备需要对应插头(协议)才能接入电源。在SDN的世界里,南向…...
AI专著撰写必备!实测8款AI工具,快速生成20万字专著且低查重率!
研究者专著创作困境与AI工具解决方案 对于多数研究者而言,编写学术专著常常面临最大的挑战,便是“有限的精力”与“无限的需求”之间的矛盾。撰写一本专著通常需要3到5年,甚至更长的时间,而研究者们平常还需要完成教学、科研项目…...
3个核心功能解决B站视频下载难题:BilibiliDown完全指南
3个核心功能解决B站视频下载难题:BilibiliDown完全指南 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_mirrors/…...
解决Raspberry Pi上的jInput库问题
引言 在使用Java开发跨平台的应用程序时,处理不同操作系统下的库文件加载问题是一个常见的挑战。尤其是在Raspberry Pi(Pi3B+)上运行时,jInput库的加载问题可能会困扰不少开发者。本文将通过一个实例,详细介绍如何解决在Raspbian64系统上jInput库加载失败的问题。 问题描…...
氨基化MIL-101(Cr)包覆四氧化三铁纳米颗粒,MIL-101(Cr)-NH₂@Fe₃O₄ NPs,反应特点
氨基化MIL-101(Cr)包覆四氧化三铁纳米颗粒,MIL-101(Cr)-NH₂Fe₃O₄ NPs,反应特点MIL-101(Cr)-NH₂Fe₃O₄ NPs(氨基化MIL-101(Cr)包覆四氧化三铁纳米颗粒)是一类在磁性纳米核表面原位生长氨基功能化金属有机骨架(MOF&…...
