前端面试题(二)
6. 深入 JavaScript
-
this
关键字的指向是什么?this
的指向是在函数执行时决定的。默认情况下,非严格模式下this
指向全局对象(浏览器中为window
),严格模式下this
为undefined
。在对象方法中,this
通常指向调用该方法的对象。而在事件处理器、构造函数等场景中,this
的指向不同。可以通过call
、apply
和bind
方法显式改变this
的指向。
-
什么是原型链?
- 每个 JavaScript 对象都有一个内部属性
[[Prototype]]
(在现代浏览器中可以通过__proto__
访问),它指向该对象的原型。原型链就是对象通过[[Prototype]]
层层向上寻找属性或方法,直到找到或到达原型链的顶端(即null
)。
- 每个 JavaScript 对象都有一个内部属性
-
如何实现 JavaScript 的继承?
- 常见的继承方法有:
- 原型继承:通过将子类构造函数的
prototype
指向父类的实例。 - 组合继承:结合构造函数和原型链继承。
- ES6 class 继承:通过
class
和extends
关键字实现继承。
- 原型继承:通过将子类构造函数的
- 常见的继承方法有:
-
什么是事件循环(Event Loop)?
- JavaScript 是单线程语言,事件循环是用于处理异步操作的机制。事件循环从任务队列中获取任务执行,任务分为微任务(Microtask,如
Promise
)和宏任务(Macrotask,如setTimeout
)。事件循环优先执行当前的微任务队列,执行完后再处理宏任务。
- JavaScript 是单线程语言,事件循环是用于处理异步操作的机制。事件循环从任务队列中获取任务执行,任务分为微任务(Microtask,如
7. 网络与性能优化
-
什么是浏览器的回流(Reflow)和重绘(Repaint)?
- 回流 是当元素的尺寸、布局或位置变化时,浏览器重新计算布局的过程,代价较大。重绘 是元素的外观样式(如颜色)发生变化时,浏览器重新绘制的过程,相比回流,重绘的代价较小。
- 优化建议包括减少对 DOM 的频繁操作、使用
transform
和opacity
来避免触发回流、批量更新 DOM。
-
如何减少页面加载时间?
- 代码分割:通过按需加载减少初始加载体积,如使用 Webpack 的代码分割功能。
- 懒加载:仅在需要时加载图片和其他资源。
- 缓存:利用 HTTP 缓存(如
Cache-Control
、ETag
)减少重复资源加载。 - CDN:将静态资源分发到多个地理位置靠近的服务器,提高下载速度。
- 合并和压缩:将 CSS 和 JS 文件合并,减少 HTTP 请求,并压缩代码减少文件体积。
-
解释 HTTP/2 和 HTTP/3 的改进?
- HTTP/2 通过引入二进制帧、多路复用(允许一个连接中同时传输多个请求),以及服务器推送(server push)等优化了 HTTP 性能。
- HTTP/3 则使用了 QUIC 协议,基于 UDP,进一步减少了连接延迟,提高了安全性和速度,尤其在不稳定的网络环境下表现优异。
8. Vue.js 和 React 深入
-
Vue 中的
watch
和computed
有什么区别?computed
是基于依赖的缓存属性,只有依赖的数据变化时,才会重新计算。适合用于有复杂计算的场景。watch
是用于监听特定数据的变化,并在变化时执行回调,适合用于响应某些数据变化时执行副作用操作,如调用 API。
-
React 中的
useEffect
和useLayoutEffect
有什么区别?useEffect
在浏览器完成渲染后异步执行,适合处理不影响页面布局的副作用。useLayoutEffect
会在 DOM 更新后立即同步执行,适合操作 DOM 或需要提前完成计算的场景。
-
React 中的
key
属性的作用是什么?key
用于帮助 React 识别哪些元素在列表中发生了变化(如被添加或移除)。有助于提高渲染性能,避免不必要的 DOM 更新。通常应当为key
提供唯一的标识符。
9. 安全与防护
-
什么是 XSS(跨站脚本攻击)?如何防御?
- XSS 是攻击者向网页中注入恶意代码,通常通过输入框、URL 参数等传递。防御措施包括:
- 对输入进行转义和过滤(如使用
encodeURIComponent
处理 URL 中的参数)。 - 使用 CSP(内容安全策略)限制可以执行的脚本源。
- 对输入进行转义和过滤(如使用
- XSS 是攻击者向网页中注入恶意代码,通常通过输入框、URL 参数等传递。防御措施包括:
-
什么是 CSRF(跨站请求伪造)?如何防御?
- CSRF 是攻击者诱使用户在已登录的情况下向受信任的网站发起非预期的请求。防御措施包括:
- 使用 CSRF token 来验证请求的合法性。
- 使用 SameSite Cookie 标志,限制跨站点的 Cookie 发送。
- CSRF 是攻击者诱使用户在已登录的情况下向受信任的网站发起非预期的请求。防御措施包括:
10. 前端测试与自动化
-
前端如何进行单元测试?
- 使用如 Jest、Mocha 等测试框架进行 JavaScript 函数和组件的单元测试。通过断言库(如 Chai)编写测试用例,确保各模块的输入输出符合预期。
-
什么是端到端测试?
- 端到端测试(E2E testing) 是通过模拟用户操作来测试整个应用程序的功能是否正常,常用工具如 Cypress 或 Selenium。它测试应用的整体流程,而不仅仅是某个独立模块。
相关文章:

前端面试题(二)
6. 深入 JavaScript this 关键字的指向是什么? this 的指向是在函数执行时决定的。默认情况下,非严格模式下 this 指向全局对象(浏览器中为 window),严格模式下 this 为 undefined。在对象方法中,this 通常…...

【C++】stack和queue的使用及模拟实现
stack就是栈的意思,这个结构遵循后进先出(LIFO)的原则,可以将栈想象为一个子弹夹,先进去的子弹后出来。 queue就是队列的意思,这个结构遵循先进先出(FIFO)的原则,可以将对列想象成我们排队买饭的场景,先排…...

MongoDB解说
MongoDB 是一个流行的开源 NoSQL 数据库,它使用了一种被称为文档存储的数据库模型。 与传统的关系型数据库管理系统(RDBMS)不同,MongoDB 不使用表格来存储数据,而是使用了一种更为灵活的格式——JSON 样式的文档。 这…...

问:JAVA中唤醒阻塞的线程有哪些?
在Java中,唤醒阻塞线程的方法有多种,以下是常见的线程唤醒方法。 唤醒方法 使用notify()和notifyAll()方法 synchronized (obj) {obj.notify(); // 唤醒单个等待线程// obj.notifyAll(); // 唤醒所有等待线程 }使用interrupt()方法 Thread thread n…...

Github Webhook触发Jenkins自动构建
1.功能说明 Github Webhook可以触发Jenkins自动构建,通过配置Github Webhook,每次代码变更之后(例如push操作),Webhook会自动通知Jenkins服务器,Jenkins会自动执行预定义的构建任务(如Jenkins …...

ESP32-WROOM-32 [创建AP站点-客户端-TCP透传]
简介 基于ESP32-WROOM-32 开篇(刚买), 本篇讲的是基于固件 ESP32-WROOM-32-AT-V3.4.0.0(内含用户指南, 有AT指令说明)的TCP透传设置与使用 设备连接 TTL转USB线, 接ESP32 板 的 GND,RX2, TX2 指令介绍 注意,下面指…...

新闻文本分类识别系统Python+卷积神经网络算法+人工智能+深度学习+计算机毕设项目+TensorFlow+Django网页界面
一、介绍 文本分类识别系统。本系统使用Python作为主要开发语言,首先收集了10种中文文本数据集(“体育类”, “财经类”, “房产类”, “家居类”, “教育类”, “科技类”, “时尚类”, “时政类”, “游戏类”, “娱乐类”),然…...

Java使用Map数据结构配合函数式接口存储方法引用
Java使用Map数据结构配合函数式接口存储方法引用 背景 需求中存在这样一直情况 一个国家下面有很多的州 每个州对应的计算日期方法是不同的 这个时候 就面临 可能会有很多if else 为了后期维护尽量还是不想采用这个方式,那么就可以使用策略模式 但是 使用策略带来的…...

LeetCode:2207. 字符串中最多数目的子序列(Java)
目录 2207. 字符串中最多数目的子序列 题目描述: 实现代码与解析: 遍历: 原理思路: 2207. 字符串中最多数目的子序列 题目描述: 给你一个下标从 0 开始的字符串 text 和另一个下标从 0 开始且长度为 2 的字符串 p…...

win10开机自启动方案总汇
win10开机自启动方案总汇 一、开始文件目录添加二、添加注册表启动程序三、服务启动3.1. 将程序注册为服务使用命令行创建服务设置服务启动类型启动服务 3.2. 使用 Windows 服务管理器配置服务3.3. 删除服务 四、定时任务或程序4.1 设置程序自启动(使用任务计划程序…...

【自动驾驶】基于车辆几何模型的横向控制算法 | Stanley 算法详解与编程实现
写在前面: 🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝 个人主页:清流君_CSDN博客,期待与您一同探索 移动机器人 领域的无限可能。 🔍 本文系 清流君 原创之作&…...

微服务--初识MQ
在微服务架构中,MQ(Message Queue,消息队列)作为一种重要的通信机制,扮演着至关重要的角色。 MQ,即消息队列,是一种在不同服务或系统之间传递消息的中间件。它允许消息的发送者(生产…...

车辆识别数据集,图片数量20500,模型已训练200轮
车辆识别数据集(Vehicle Recognition Dataset, VDRD) 摘要 VDRD 是一个专为车辆识别设计的大规模数据集,它包含了20500张不同类型的汽车、货车、公交车以及其他类型车辆的图像。数据集提供了四种车辆类别:汽车、货车、其他车辆和…...

MES系统如何提升制造企业的运营效率和灵活性
参考拓展:苏州稳联-西门子MES系统-赋能智能制造的核心引擎 制造执行系统(MES)在提升制造企业运营效率和灵活性方面发挥着关键作用。 一、MES系统的基本概念和功能 MES系统是连接企业管理层与生产现场的重要桥梁。它主要负责生产调度、资源管理、质量控制等多个方…...

Nexpose 6.6.270 发布下载,新增功能概览
Nexpose 6.6.270 for Linux & Windows - 漏洞扫描 Rapid7 Vulnerability Management, release Sep 18, 2024 请访问原文链接:https://sysin.org/blog/nexpose-6/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.or…...

【数据库】sqlite
文章目录 1. 基本概述2. 主要特点3. 应用场景4. 优缺点5. 基本使用示例6. 在编程语言中的使用连接到 SQLite 数据库(如果文件不存在会自动创建)创建表插入数据提交事务查询数据关闭连接 7. 总结 SQLite 是一个轻量级的关系型数据库管理系统(R…...

详解 C++中的模板
目录 前言 一、函数模板 1.定义 2.函数模板的实现 3.模板函数的实例化 4.模板参数的省略 1.函数模板的实参推导 2.类模板的实参推导 3.默认模板参数 4.特殊情况:无法推导的模板 5.推导失败的情况 二、类模板 1.概念和定义 2.类模板定义 3.类模板的使用 4.类模板…...

基于DAMODEL——Faster-RCNN 训练与测试指南
Faster-RCNN 训练与测试指南 前言 今天我们要来实现一个经典的目标检测模型:Faster-Rcnn。我们使用DAMODEL云平台来实现,这是个很强大的云端平台,功能众多,你可以投你所好去进行你想做的事情。 1. 环境与工具准备 1.1 远程连接…...

考研数据结构——C语言实现冒泡排序
冒泡排序是一种简单的排序算法,它重复地遍历要排序的列表,比较每对相邻元素,并在顺序错误的情况下交换它们。这个过程重复进行,直到没有需要交换的元素,这意味着列表已经排序完成。冒泡排序的名字来源于较小的元素会逐…...

labview更换操作系统后打开原VI闪退
labview更换操作系统后打开原VI闪退 问题描述: Windows11由家庭版更换为专业版后,重新安装labview2021,打开原来的项目,项目管理器可以正常打开,但是打开VI却闪退,并报错如下 出现这种原因主要是labview在…...

什么是CAPTCHA?有什么用途?
一、CAPTCHA 的工作原理 CAPTCHA的核心目的是通过呈现人类可以轻松理解但计算机程序难以解决的任务,来阻止恶意的自动化工具。传统的CAPTCHA通过展示扭曲或模糊的文字、图片或者点击操作等,要求用户完成验证任务。这些任务通常需要视觉、听觉或简单的逻辑…...

在虚幻引擎中创建毛发/头发
在虚幻引擎中创建毛发/头发 , 首先开启两个插件 Groom 和 Alembic Groom Importer 打开蒙皮缓存 导出人物模型 将人物导入Blender , 选择需要种植头发的点 指定并选择 点击毛发 这里变成爆炸头了 , 把数量和长度调一下 切换到梳子模式 调整发型 导出为abc , 文件路径不…...

PHP API 框架:构建高效API的利器【电商API接口】
在当今快速发展的互联网时代,API(应用程序编程接口)已成为连接不同应用程序和服务的关键。PHP,作为一种流行的服务器端脚本语言,提供了多种强大的框架来简化API的开发。本文将介绍PHP API框架的重要性,以及…...

transformer模型写诗词
加入会员社群,免费获取本项目数据集和代码:点击进入>> 1. 项目简介 该项目是基于A035-transformer模型的诗词生成系统,旨在通过深度学习技术实现古诗词的自动化创作。项目的背景源自当前自然语言处理领域的迅速发展,特别是…...

[大语言模型-工程实践] 手把手教你-基于Ollama搭建本地个人智能AI助理
[大语言模型-工程实践] 手把手教你-基于Ollama搭建本地个人智能AI助理 Note: 草稿优化中,持续更新,相关代码将统一提供出来~ 1. Ollama简介 Ollama 是一个用于在本地环境中运行和定制大型语言模型的工具。它提供了一个简单而高效的接口,用于…...

开放原子开源基金会OPENATOM
AtomGit_开放原子开源基金会代码托管平台-AtomGit 开放原子开源基金会是致力于推动全球开源事业发展的非营利机构,于 2020 年 6 月在北京成立,由阿里巴巴、百度、华为、浪潮、360、腾讯、招商银行等多家龙头科技企业联合发起。 精选项目: 比…...

Docker的监控:docker stats与docker events
Docker的监控:docker stats与docker events 1. 使用`docker stats`监控资源2. 使用`docker events`监控活动3、建议💖The Begin💖点点关注,收藏不迷路💖 Docker提供了docker stats和docker events两个简单而强大的工具来帮助我们监控容器。 1. 使用docker stats监控资…...

jvm专题 之 内存模型
文章目录 前言一个java对象的运行过程jvm内存分布程序的基本运行程序什么是对象?对象与类的关系?由类创建对象的顺序 前言 一个程序需要运行,需要在内存中开辟一块空间类是构建对象的模板,只有类加载到内存中才能创建对象 一个j…...

分布式计算框架
进入Scala模式 终端里输入Scala 创建一个新的Scala文件 vim 文件名.scala 复制粘贴代码 ctrlshift c/v 使用vim 先进入插入模式,可以通过按i键来实现,然后粘贴代码,完成后按Esc键退出插入模式,保存并退出可以通过输入:wq然后按…...

YOLO交通目标识别数据集(红绿灯-汽车-自行车-卡车等)
YOLO交通目标识别 数据集 模型 ui界面 ✓图片数量15000,xml和txt标签都有; ✓class:biker,car,pedestrian,trafficLight,trafficLight-Green,trafficLight-GreenLeft, t…...