跟前端架构说easy(3):架构设计
xsobi 2025-01-04 23:51 2 浏览
架构设计就好比是搭建高楼的架子,这个高楼最后什么形状、是否稳健,全部看这个架构设计这个架子的稳定性和扩展性。
团队技术栈
我们团队是在长期学习和沉淀中,逐渐形成了以uniapp和vue两大技术为主,同时保留了一定微信小程序、Android原生、iOS原生的开发能力,技术架构我主要会从uniapp和vue做说明和分析。
uniapp的架构设计
我们是使用uniapp技术,基于自己的前端开发规范,通过调用后台接口来实现我们的业务需求。
1. 网络层
网络层的设计会分为三部分,底层、过渡层、调用层,底层重点是稳定性、可扩展性,调用层的使用一定是要简单方便,所以我们会在中间层根据这个项目的要求做更多灵活的封装。这部分直接上代码:
//基础层
const baseRequest = (args) => {
//args 会有url、param、header、method等信息,
//这部分一定要充分考虑,因为底层就是地基,不可随意改变
}
//过渡层
let execApi = (url, method, param, loadingTip, hideErrorMsg = false, loginType = 1) => {
// 通过本项目的业务,参数可以细化,多增加默认值,方便调用
}
//过渡层进一步封装
let postApi = (url, param, loadingTip) => {
return execApi(url, "POST", param, loadingTip)
}
let getApi = (url, param, loadingTip) => {
return execApi(url, "GET", param, loadingTip)
}
//调用层
register:(param) => requestUtil.postApi('/api/user/register',param),
2. 基础层封装
基础层的封装其实也是规范的一种,网络层+基础层是为了更好的建立统一,为业务组件的封装打下基础,让业务组件能够在多项目中快速复用,同时保持一套基础层的维护。
3. 组件封装
组件主要分为UI组件和业务组件。UI组件主要是根据某些设计的要求,实现一些界面展示。业务组件主要是针对业务的封装,能够将该业务快速复制到其他项目中使用。业务组件拥有自己所特有的UI组件、工具类以及界面,另外每个业务组件必须有使用说明的readme.md。具体结构如下图:
vue的架构设计
我们是使用antdesign和element两个UI框架,基于自己的前端开发规范,通过调用后台接口来实现我们的业务需求。vue也是做了网络层、服务层、工具层、组件等,这部分和uniapp的基本类似,就不再重复描述。
架构的目的
架构的好处有很多,比如说会给我带来稳健、可扩展的程序等等。在作者来看,架构设计的很重要的一个目的就是提高效率,作者希望用10%-20%的架构时间来赚取50%的项目时间,用赚取的项目一部分回馈到架构时间,逐渐形成良性循环。
The END
如果您觉得这篇内容对您有帮助,我想请你帮我两个小忙:
1、给作者点个赞,分享让更多的人也能看到这篇文章
2、关注头条号「前端百思说」,加入我们一起学习
点赞、转发、关注头条号,私信“学习资料”向小编索取更多VUE相关的资料
上一篇文章
- 上一篇:C++中的多态(动态多态)究竟是如何实现
- 下一篇:审批流而已 | so easy!
相关推荐
- MySQL 正则表达式最全介绍
-
MySQL支持使用正则表达式进行模式匹配和文本搜索。正则表达式提供了一种强大的工具,可以用来匹配和检索字符串中的复杂模式。MySQL中的正则表达式功能主要在REGEXP或RLIKE运算符中使用。1....
- 正则前面的 (?i) (?s) (?m) (?is) (?im) 是什么意思
-
Q:经常看见的正则前面的(?i)(?s)(?m)(?is)(?im)是什么意思?...
- SQL中的正则表达式
-
正则表达式通常用来匹配字符,比如在一段字符中截取我们想要的字符,又或者将不想要的字符串替换,或者统计某个或者某几个字符出现的次数,我们都可以使用Oracle提供的正则表达式语法来完成。1.比如,我们在...
- 学习VBA,报表做到飞 第四章 正则表达式 4.10 贪婪模式与懒惰模式
-
第四章正则表达式4.10贪婪模式与懒惰模式正则表达式匹配时默认为贪婪模式,也就是尽可能多的匹配。有时候我们需要对符合条件的内容分开匹配,就要用到懒惰模式。...
- Python re模块 正则表达式之compile函数
-
一、应用场景为了重复利用同一个正则对象,需要多次使用这个正则表达式的话,使用re.compile()保存这个正则对象以便复用,可以让程序更加高效。二、使用方法...
- 几条常用的JavaScript正则表达式
-
在做项目或者代码编写过程中,一般会遇到验证电话、邮箱等格式是否正确合法的问题。通常我们会使用正则表达式,自己写很麻烦,且正则表达式又不是那么容易记住。所以现在分享几条常用的正则表达式,需要的时候直接复...
- C语言中使用正则表达式
-
POSIX规定了正则表达式的C语言库函数,参见regex(3),我们已经学了很多C函数的用法读者应该具备自己看懂man手册的能力C语言中使用正则表达式一般分为三步:1.编译正则表达式regco...
- VBA与Excel入门系列-12-正则表达式(上篇)
-
系统环境:Windows10...
- 系列专栏(八):JS的第七种基本类型Symbols
-
ES6作为新一代JavaScript标准,已正式与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,MozillaWeb开发者博客推出了《ES6InDepth》系列文章。CSDN...
- EXCEL正则表达式的基础语法
-
正则表达式的基本概念及用途了解之后,我们就来学习下具体的语法,先以一个简单的例子来讲解。基础语法:比如,A1单元格中有一串字符:aabbccdd...
- 这几个冷门到你没听过的App,好用到为你打开新世界大门
-
一些好用的App总被埋没在数以百万计的应用商店中。今天为大家推荐几款Windows、Android、iOS、macOS平台里略显小众、但足够好用的遗珠App。万彩办公大师(Windows)转换Offi...
- C/C++知识分享:C语言正则表达式
-
C语言的正则表达式规则,特此跟大家分享。一、C语言如何使用正则表达式?C语言使用正则表达式的方法很简单,只需要包含正则表达式头文件即可:...
- Github工具库(二)
-
作者:Yunying...
- 在 JavaScript 中替换所有指定字符 3 种方法
-
在JS没有提供一种简便的方法来替换所有指定字符。在Java中有一个replaceAll(),replaceAll(Stringregex,Stringreplacement))方法...
- 正则表达式进阶
-
正则表达式,是每个程序员的必备的技能1.贪婪匹配和惰性匹配...
- 一周热门
- 最近发表
- 标签列表
-
- grid 设置 (58)
- 移位运算 (48)
- not specified (45)
- patch补丁 (31)
- 导航栏 (58)
- context xml (46)
- scroll (43)
- dedecms模版 (53)
- c 视频教程下载 (33)
- listview排序 (33)
- firebug 使用 (31)
- characterencodingfilter (33)
- getmonth (34)
- hibernate教程 (31)
- label换行 (33)
- curlpost (31)
- android studio 3 0 (34)
- android应用开发 (31)
- html转js (35)
- 索引的作用 (33)
- css3 0 (31)
- checkedlistbox (34)
- localhost 8080 (32)
- 多态 (32)
- net开发 (31)