技能特⻓回答

一、JavaScript 基础

常用 ES6+ 语法:

箭头函数、模板字符串、解构赋值、spread/rest、默认参数
Promise/async-await、class、模块(import/export)
Set/Map、可选链(?.)、空值合并(??)、大数(BigInt)
let/const/var 区别:

var:函数级作用域,可提前(hoisting),易污染全局
let:块级作用域,不可重复声明,有暂时性死区
const:块级作用域,声明后不可改引用,适合常量或不变引用
Promise 使用场景:

并发请求:Promise.all([req1, req2, …]).then(results=>{ … })/async-await + Promise.all
串行请求:chain then 或 for await…of
拦截统一错误/超时封装
回调地狱解决:

用 Promise 链式调用或 async-await
将重复逻辑封装成函数/工具库(如 p-limit 控制并发)
二、Vue 相关

常用生命周期钩子:

created:数据/状态初始化,不可操作真实 DOM
mounted:首次挂载完成,可操作 DOM/调用第三方库
beforeUnmount/unmounted:清理定时器、事件监听
watch/computed:数据变更响应
v-if vs v-show:

v-if:动态增删 DOM,初次渲染有开销,适合不频繁切换
v-show:始终渲染,仅控制 display,频繁切换时优先
组件间通信:

父子:props + $emit
兄弟/跨层级:EventBus(不推荐)、provide/inject、Vuex/Pinia、mitt
Vuex/Pinia 用处:

管理用户信息(token、权限)、全局配置、购物车、Tab 标签状态等
性能优化:

路由懒加载(defineAsyncComponent)
组件按需加载、keep-alive 缓存
图片懒加载、虚拟列表(vue-virtual-scroller)
减少重复渲染(合理拆组件、使用 key)
三、工程化与工具

Webpack/Vite 常改配置:

alias(@ 指向 src)、devServer proxy 跨域、环境变量定义
打包体积分析(webpack-bundle-analyzer)、代码分割
Loader vs Plugin:

Loader:文件预处理(如 babel-loader、css-loader)
Plugin:打包生命周期扩展(如 HtmlWebpackPlugin、DefinePlugin)
代码风格统一:

ESLint + Prettier 联动,husky + lint-staged 在 Git 提交前校验
提炼公共组件:

根据设计需求抽象通用弹窗、表单输入框、表格、卡片等;通过 props/slot 参数化
四、网络与调试

联调排查流程:

检查前端请求参数/URL
Network 面板看状态码、返回值
console.log、断点调试、Mock 数据对比
后端日志/接口文档核对
跨域解决:

CORS(后端设置)、devServer proxy、Nginx 反向代理、JSONP(仅 GET)
项目常用 devServer proxy
常用 F12 面板:

Elements(DOM/样式)、Network(接口)、Console(日志)、Sources(断点)、Performance(性能分析)
五、权限与若依框架

动态路由流程:

登录后接口获取菜单树
递归生成 Vue Router 路由配置
router.addRoutes/router.addRoute 动态注入
按钮权限控制:

基于指令(v-permission)或高阶组件封装,如:
六、小程序与可视化

小程序 vs Vue:

生命周期不同(onLoad/onShow vs created/mounted)
API 调用 wx.request、wx.navigateTo
无 DOM,使用 wxml/wxss 语法
大屏适配:

百分比+flex 布局、rem/视口 vw 单位
ECharts resize 自适应容器
ECharts 常用图表:

折线、柱状、饼图、地图、漏斗图
大数据量卡顿:启用 canvas 渲染,数据 down-sampling,数据分批加载
七、其他常用库

Axios 封装:

创建实例统一 baseURL、超时
请求拦截器加 token、loading;响应拦截器统一错误提示、状态码处理
UI 库二次封装:

封装统一主题/全局配置、自定义表单组件、增强提示功能,使项目样式更一致
Git 常用命令:

clone、checkout、branch、merge/rebase、stash、pull、push
开发中切分支修 bug:git stash,checkout bug-branch,修复后 git stash pop,再提交
八、综合与项目

项目简介:

“智慧校园管理平台”:负责前端架构、权限模块、报表大屏
挑战:百万级数据列表性能、动态路由权限控制
解决:虚拟列表组件、后端分页+按需加载;动态路由缓存与导航守卫
职业规划:

深耕前端技术栈(框架、性能、安全)
学习全栈/Node.js 后端,承担更多架构设计
关注用户体验与团队协作,提升软技能与领导力

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值