技术栈:vue + element + vuex + webpack + axios + async-validator
多语言采用:vue-i18n 切换语言不需要刷新页面
权限控制:采用element admin 的路由拦截器 集成了 白名单 验证token功能
单页面(SPA single page web application)
data:image/s3,"s3://crabby-images/deb0f/deb0f1a1b9f61435ad6c3e59e663976726296a7b" alt=""
优:
1.分离前后端关注点,各司其职
2.用户体验好、快,内容的改变不需要重新加载整个页面 不操作DOM(成本最高的操作)
3.服务器只接口提供数据,不用考虑页面逻辑和页面合成,提高性能
4.可以缓存较多数据,减少服务器压力
缺:
1.SEO问题
2.首次加载慢
3.用户操作需要写逻辑,前进、后退等(像native应用一样)
4.页面复杂度提高,复杂逻辑难度倍增
组件化
开发就是在写组件
data:image/s3,"s3://crabby-images/11436/1143668957277f902203b8228304bcbbfc0987d5" alt=""
上传组件的封装
data:image/s3,"s3://crabby-images/d05da/d05da39ff99cbf110a01962eca437e8e69388a10" alt=""
文件打包
现在打包时已经没有静态资源
测试时打包为 22.3 KB
data:image/s3,"s3://crabby-images/4e415/4e4154bd0ce3f0a1b5ff4329a87b808085429fab" alt=""
之前官网为 817MB
data:image/s3,"s3://crabby-images/742d7/742d75a13551feea0a030d97b4c48a793a616642" alt=""
data:image/s3,"s3://crabby-images/c621a/c621afd7632849400be54f13f0b9840efb920e5c" alt=""
async-validator表单验证 分离测试接口url 和正式接口url 存储为全局变量方便调用 等等
网友评论