2024 前端面试题及答案,2024年最新2024网易前端高级面试题总结

本文分享了一位技术专家的经验,推荐一份全面的Web前端学习资料,涵盖基础知识、进阶课程、性能优化技巧、框架如Vue和React的核心概念,以及职业发展建议,旨在帮助程序员高效系统学习和提升技术能力。
摘要由CSDN通过智能技术生成

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

  • 通过伪元素

.content:before{

content: ‘’;

position: absolute;

width: 200%;

height: 1px;

bottom: 0;

border-bottom: 1px solid #d6e4ed;

-webkit-transform-origin: 0 0;

transform-origin: 0 0;

-webkit-transform: scale(.5,.5);

transform: scale(.5,.5);

-webkit-box-sizing: border-box;

box-sizing: border-box

}

  • 也可以实用背景渐变一半有色一半透明

9.性能优化(主要考察http和https,不能只说是代码封装方面的)

  • 控制图片大小/图片懒加载

  • 减少http请求(节流)

  • 代码高内聚低耦合

  • 使用事件委托(使用事件委托可以节省内存)

10.数据类型(也考察存的是堆还是栈)

(基本类型):String、Number、Boolean、Null、Undefined、Symbol。

引用数据类型:Object、Array、Function。

11.闭包

闭包就是一个函数,两个函数彼此嵌套,内部函数就是闭包形成闭包条件

缺点:易造成内存泄漏不会被垃圾回收机制回收

12.es6新特性及es7,8

let,const,箭头函数,promise,class,解构赋值,export,模版字符串,(…扩展符)

13.map和set

  • Map是一组键值对的结构,具有极快的查找速度

  • SetMap类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在Set中,没有重复的key。

14.webpack

  • mode:编译模式

entry:编译起始文件

loaders:文件资源的转换

plugins:提供额外功能的插件

output:编译结果文件输出

15.js的原型和原型链

  • 原型:所有的函数都有一个特殊的属性prototype(原型),prototype属性是一个指针,指向的是一个对象(原型对象),原型对象中的方法和属性都可以被函数的实例所共享。所谓的函数实例是指以函数作为构造函数创建的对象,这些对象实例都可以共享构造函数的原型的方法。

  • 原型链:原型链是用于查找引用类型(对象)的属性,查找属性会沿着原型链依次进行,如果找到该属性会停止搜索并做相应的操作,否则将会沿着原型链依次查找直到结尾。常见的应用是用在创建对象和继承中。

16.浏览器渲染流程

  • DNS解析:把域名解析成IP地址

  • TCP 建立连接:TCP三次握手

  • 发送HTTP请求

  • 服务器处理并响应报文

  • 浏览器解析并渲染页面

  • 断开连接:TCP 结束连接

17.跨域

18.vue生命周期

19.vue双向绑定

20.vue组件通讯

21.vuex

22.vue路由

23.vuex的使用场景及和全局变量的区别

24.rem、em、px、vh,vw

react

=====

1.当你调用 setState 的时候,发生了什么事?

将传递给 setState 的对象合并到组件的当前状态,这将启动一个和解的过程,构建一个新的 react 元素树,与上一个元素树进行对比( diff ),从而进行最小化的重渲染。

2.React 项目用过什么脚手架(本题是开放性题目)

creat-react-app Yeoman 等

3什么时候用类组件Class Component,或函数组件Function

如果您的组件具有状态( state ) 或 生命周期方法,请使用 Class 组件。否则,使用功能组件

4.React 中 keys 的作用是什么?

Keys 是 React 用于追踪哪些列表中元素被修改、被添加或者被移除的辅助标识。

5.React 优势

1)、React 速度很快:它并不直接对 DOM 进行操作,引入了一个叫做虚拟 DOM 的概念,安插在 javascript 逻辑和实际的 DOM 之间,性能好。

2)、跨浏览器兼容:虚拟 DOM 帮助我们解决了跨浏览器问题,它为我们提供了标准化的 API,甚至在 IE8 中都是没问题的。

3)、一切都是 component:代码更加模块化,重用代码更容易,可维护性高。

4)、单向数据流:Flux 是一个用于在 JavaScript 应用中创建单向数据层的架构,它随着 React 视图库的开发而被 Facebook 概念化。

5)、同构、纯粹的 javascript:因为搜索引擎的爬虫程序依赖的是服务端响应而不是 JavaScript 的执行,预渲染你的应用有助于搜索引擎优化。

6)、兼容性好:比如使用 RequireJS 来加载和打包,而 Browserify 和 Webpack 适用于构建大型应用。它们使得那些艰难的任务不再让人望而生畏。

6.react diff 原理(常考,大厂必考)

把树形结构按照层级分解,只比较同级元素。

给列表结构的每个单元添加唯一的 key 属性,方便比较。

React 只会匹配相同 class 的 component(这里面的 class 指的是组件的名字) 合并操作,调用 component 的 setState 方法的时候, React 将其标记为 dirty.

到每一个事件循环结束, React 检查所有标记 dirty 的 component 重新绘制. 选择性子树渲染。开发人员可以重写 shouldComponentUpdate 提高 diff 的性能

7react 生命周期函数

运行中:

getDefaultProps:获取实例的默认属性

getInitialState:获取每个实例的初始化状态

componentWillMount:组件即将被装载、渲染到页面上

render:组件在这里生成虚拟的 DOM 节点

componentDidMount:组件真正在被装载之后

运行中状态:

componentWillReceiveProps:组件将要接收到属性的时候调用

shouldComponentUpdate:组件接受到新属性或者新状态的时候(可以返回 false,接收数据后不更新,阻止 render 调用,后面的函数不会被继续执行了)

componentWillUpdate:组件即将更新不能修改属性和状态

render:组件重新描绘

componentDidUpdate:组件已经更新

销毁阶段:

componentWillUnmount:组件即将销毁

9

React 中 refs 的作用是什么?

Refs 是 React 提供给我们的安全访问 DOM 元素或者某个组件实例的句柄。

我们可以为元素添加 ref 属性然后在回调函数中接受该元素在 DOM 树中的句柄,该值会作为回调函数的第一个参数返回:

class CustomForm extends Component {

handleSubmit = () =› {

console.log('Input Value: ', this.input.value);

};

render() {

return (

‹form onSubmit={this.handleSubmit}›

‹input type=‘text’ ref={input =› (this.input = input)} /›

‹button type=‘submit’›Submit‹/button›

‹/form›

);

}

}

上述代码中的 input 域包含了一个 ref 属性,该属性声明的回调函数会接收 input 对应的 DOM 元素,我们将其绑定到 this 指针以便在其他的类函数中使用。

另外值得一提的是,refs 并不是类组件的专属,函数式组件同样能够利用闭包暂存其值:

function CustomForm({ handleSubmit }) {

let inputElement;

return (

‹form onSubmit={() =› handleSubmit(inputElement.value)}›

‹input type=‘text’ ref={input =› (inputElement = input)} /›

‹button type=‘submit’›Submit‹/button›

‹/form›

);

}

10setState 和 replaceState 的区别

setState 是修改其中的部分状态,相当于 Object.assign,只是覆盖,

不会减少原来的状态

replaceState 是完全替换原来的状态,相当于赋值,将原来的 state 替换为另一个对象,如果新状态属性减少,那么 state 中就没有这个状态了

11React 中有三种构建组件的方式

React.createClass()、ES6 class 和无状态函数。

12描述事件在 React 中的处理方式

为了解决跨浏览器兼容性问题,您的 React 中的事件处理程序将传递 SyntheticEvent 的实例,它是 React 的浏览器本机事件的跨浏览器包装器。

这些 SyntheticEvent 与您习惯的原生事件具有相同的接口,除了它们在所有浏览器中都兼容。

有趣的是,React 实际上并没有将事件附加到子节点本身。

React 将使用单个事件监听器监听顶层的所有事件。

这对于性能是有好处的,这也意味着在更新 DOM 时,React 不需要担心跟踪事件监听器。

13应该在 React 组件的何处发起 Ajax 请求

在 React 组件中,应该在 componentDidMount 中发起网络请求。这个方法会在组件第一次“挂载”(被添加到 DOM)时执行,在组件的生命周期中仅会执行一次。

更重要的是,你不能保证在组件挂载之前 Ajax 请求已经完成,如果是这样,也就意味着你将尝试在一个未挂载的组件上调用 setState,这将不起作用。

在 componentDidMount 中发起网络请求将保证这有一个组件可以更新了。

总结

我在成长过程中也是一路摸爬滚打,没有任何人的指点,所以走的很艰难。例如在大三的时候,如果有个学长可以阶段性的指点一二,如果有已经工作的师兄可以告诉我工作上需要什么,我应该前面的三年可以缩短一半;后来去面试bat,失败了有5、6次,每次也不知道具体是什么原因,都是靠面试回忆去猜测可能是哪方面的问题,回来学习和完善,当你真正去招人的时候,你就会知道面试记录是多么重要,面试官可以从面试记录里看到你的成长,总是去面试,总是没有成长,就会被定义为缺乏潜力。

image
image

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
阶段性的指点一二,如果有已经工作的师兄可以告诉我工作上需要什么,我应该前面的三年可以缩短一半;后来去面试bat,失败了有5、6次,每次也不知道具体是什么原因,都是靠面试回忆去猜测可能是哪方面的问题,回来学习和完善,当你真正去招人的时候,你就会知道面试记录是多么重要,面试官可以从面试记录里看到你的成长,总是去面试,总是没有成长,就会被定义为缺乏潜力。

[外链图片转存中…(img-eWy0YT5i-1713018973814)]
[外链图片转存中…(img-cn7wu3sI-1713018973814)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-pMjMTBBH-1713018973814)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,我无法提供完整的2024前端面试题答案,因为这些问题是根据具体公司和岗位需求而定的,而且在2024之前还有很长的时间,技术可能会有所变化。但是我可以给你提供一些常见的前端面试题答案作为参考: 1. 什么是盒模型?盒模型有哪些属性? 答:盒模型是指在网页中,每个元素都被看作是一个矩形的盒子,包括内容区域、内边距、边框和外边距。盒模型的属性有width、height、padding、border和margin。 2. 请解释一下CSS选择器的优先级。 答:CSS选择器的优先级是用来确定当多个规则应用于同一个元素时,哪个规则将会被应用。优先级从高到低依次为:!important > 内联样式 > ID选择器 > 类选择器/属性选择器/伪类选择器 > 元素选择器/伪元素选择器。 3. 请解释一下什么是闭包,并举一个例子。 答:闭包是指函数可以访问其词法作用域以外的变量。一个简单的闭包例子是: ``` function outer() { var x = 10; function inner() { console.log(x); } return inner; } var closure = outer(); closure(); // 输出10 ``` 4. 请解释一下什么是跨域,以及如何解决跨域问题。 答:跨域是指在浏览器中,一个域下的网页获取另一个域下的资源时遇到的限制。常见的解决跨域问题的方法有:JSONP、CORS、代理服务器等。 5. 请解释一下什么是响应式设计。 答:响应式设计是指网页能够根据不同设备的屏幕尺寸和分辨率进行自适应布局和显示,以提供更好的用户体验。常见的响应式设计方法有使用媒体查询、弹性布局和流式布局等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值