- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
前端工程师面试题及答案(贴近实战版)
一、基础语法与核心概念
1.为什么有时候写了CSS样式却不生效?可能有哪些原因?
答案:实际开发中遇到过不少次,常见原因有这几种:
优先级问题:比如写了.box样式,但元素同时有内联样式style=,或者有更具体的选择器(如#box.content)覆盖了;另外如果样式加了!important且冲突,也会影响生效。
选择器匹配问题:比如类名写错(比如.box写成.bxo)、标签名对应错(比如用div选择器但元素是span),或者后代选择器层级不对(比如nav.link但link不在nav里面)。
样式本身无效:比如给行内元素(如span)设置width/height却没加display:inline-block;或者属性值写错(比如color:re而不是red)。
作用域问题:如果用了Vue/React这类框架,样式加了scoped,但想修改子组件样式却没加::v-deep(Vue)或:global(React),导致样式被隔离。
2.说说你对JavaScript原型链的理解?实际项目中怎么用它优化代码?
答案:原型链本质是JS实现继承的机制——每个对象都有__proto__(隐式原型),指向它的构造函数的prototype(显式原型),当访问对象属性时,找不到就会顺着原型链往上找,直到Ototype。
实际项目里很少直接改原型(容易全局污染),但会用它的特性优化:
复用方法:比如写工具类时,把公共方法挂在构造函数的prototype上,而不是每次实例化都创建新方法。比如做表格组件时,Ttotype.formatDate只定义一次,所有表格实例都能复用,减少内存占用。
理解框架原理:比如Vue2的实例方法($emit、$on)就是挂在Vtotype上的,所以每个组件实例都能调用;React的Component类也是基于原型链,子类组件继承后能用到setState这些方法。
注意避坑:比如不要直接修改Atotype加方法(比如Atotype.myPush),会影响所有数组,包括第三方库的数组,容易出bug。
3.异步请求中,Promise和async/await怎么用?如果多个请求需要并行处理,出错了该怎么处理?
答案:日常接口请求基本都用这俩,比回调地狱清爽多了。
基础用法:比如调一个列表接口,用Promise是axios.get(/list).then(res={}).catch(err={});用async/await就是先写asyncfunctiongetList(){try{constres=awaitaxios.get(/list)}catch(err){}},后者代码更像同步,读起来方便。
并行处理:如果多个请求互不依赖(比如同时获取用户信息和商品列表),用Promise.all,比如Promise.all([axios.get(/user),axios.get(/goods)]).then(([userRes,goodsRes])={})。但要注意:Promise.all只要有一个请求失败,整个就会进catch,实际项目中如果想“某个请求失败不影响其他”,就用Promise.allSettled,然后遍历结果判断每个请求的status是fulfilled还是rejected,比如:
constresults=awaitPromise.allSettled([getUser(),getGoods()])
results.forEach(result={
if(result.status===fulfilled){
console.log(成功数据:,result.value)
}else{
console.log(失败原因:,result.reason)//单独处理失败,不阻断其他
}
})
二、工程化与工具链
1.webpack打包体积太大,怎么优化?说几个你实际用过的方案
答案:之前做管理系统时,打包后vendor.js有2.3M,优化后降到500K左右,主要用了这些方法:
代码分割:用splitChunks把第三方库(vue、axios、echarts)和业务代码拆分开,比如把echarts单独拆成一个chunk,因为不是所有页面都用图表,这样首屏不用加载它;另外路由懒加载(constHome=()=import(./Home.vue)),每个路由对应一个chunk
您可能关注的文档
最近下载
- 凯乐石冲锋衣品牌小红书营销方案.pdf VIP
- SIM卡的技术规范.doc VIP
- 中医技术规范 麦粒灸治疗不寐.docx VIP
- 北京理工大学《模拟电子技术基础》2022-2023学年第一学期期末试卷.doc VIP
- 消防水泵安全要求-GB50974.pdf VIP
- 新上一台天然气锅炉改造项目环境影响报告表全本.pdf
- 格力应收账款管理制度.docx VIP
- 老旧小区改造、提升项目部与小区居民、单位协调方案.pdf VIP
- 2025安徽皖信人力资源管理有限公司招聘某政务热线话务员招聘10人模拟试卷含答案详解.docx VIP
- DBJ51T 153-2020 四川省附着式脚手架安全技术标准.pdf VIP
原创力文档


文档评论(0)