前端mv框架下(目前写的是vue),对组件抽象的思考

简介: 前沿:  抽象是门大学问。前端mv框架中,以组件化的概念为主。经常会考虑抽象到组件级别,进行复用。合理的抽象,能提高效率,减少业务逻辑视图的耦合程度。不合理的抽象,则会增加代码的复杂程度。 遇到的问题 合理的抽象是很难的,需要不断的思考,才能做到最合适的抽象。

前沿:

  抽象是门大学问。前端mv框架中,以组件化的概念为主。经常会考虑抽象到组件级别,进行复用。合理的抽象,能提高效率,减少业务逻辑视图的耦合程度。不合理的抽象,则会增加代码的复杂程度。

 

遇到的问题

 合理的抽象是很难的,需要不断的思考,才能做到最合适的抽象。在b+项目中,遇到了一些问题。

  1、有些组件,ui和逻辑都可复用。ui抽象了,对应逻辑没抽。这样在复用这个组件的时候,逻辑部分的代码没有复用到,得另外复制粘贴一份。   

  2、有些组件,ui可复用,逻辑不可复用。抽象成一个组件,ui是实现了复用,但是业务逻辑得配置参数使用,导致switch case 无限增多。

 

我所理解的抽象思维:

  1、基础抽象,适用于所有的项目。

    首先,从功能的纬度去抽象。抽象一些具有某一特定功能的ui组件。比如说,button,日期选择器,列表等,这些都是具有特定功能的模块,单独可抽象为一个组件模块。功能型抽象的理念是,不关心具体项目的业务逻辑,只关心具体功能的逻辑。这种抽象的最终结果就是抽象出一整套具备各种功能模块的ui库。例如elemntui,antd,vant等。

  2、业务模块的抽象,根据业务逻辑判断。

    在具体项目中,除了从功能模块先抽象最基本的一层。还可以根据业务的实际需求,基于基础抽象的组件库,进行二次封装,以达到此项目中具有通用性的抽象模块。判断可抽象的依据是,ui具有一致性且业务逻辑也一致性(主要判断条件)。一个的反面例子,假如有三个模块,每个模块的列表都是长得差不多,但是三个模块的业务逻辑是不一致的,比如说接口调的不一样。这种情况下,虽然ui很像,但是逻辑不一样,就不合适抽象组件进行复用。一个正面例子,假如有一个多个下注按钮,ui稍有不同,但是实现的逻辑都是下注。那么就适合做抽象复用。

 

总结:

  通用的功能性模块有限,所以是可配置并可抽象的。业务型逻辑的情况可能无限,不合适去做配置实现抽象。所以,在业务中能抽象的必要条件是,业务逻辑必须具有一致性。如果ui也一致,则可抽象成组件。如果ui不一致,则单独抽象逻辑部分(这vue中可用minxins引入公共逻辑)。

 

目录
相关文章
|
5天前
|
前端开发 JavaScript
Bootstrap Web 前端 UI 框架
Bootstrap 是快速开发 Web 应用程序的前端工具包。
17 3
|
6天前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】React与Vue:前端框架的巅峰对决与选择策略
|
7天前
|
缓存 JavaScript UED
Vue 中实现组件的懒加载
【10月更文挑战第23天】组件的懒加载是 Vue 应用中提高性能的重要手段之一。通过合理运用动态导入、路由配置等方式,可以实现组件的按需加载,减少资源浪费,提高应用的响应速度和用户体验。在实际应用中,需要根据具体情况选择合适的懒加载方式,并结合性能优化的其他措施,以打造更高效、更优质的 Vue 应用。
|
6天前
|
前端开发 JavaScript 数据管理
React与Vue:两大前端框架的较量与选择策略
【10月更文挑战第23天】React与Vue:两大前端框架的较量与选择策略
|
11天前
|
JavaScript 前端开发 测试技术
前端全栈之路Deno篇(五):如何快速创建 WebSocket 服务端应用 + 客户端应用 - 可能是2025最佳的Websocket全栈实时应用框架
本文介绍了如何使用Deno 2.0快速构建WebSocket全栈应用,包括服务端和客户端的创建。通过一个简单的代码示例,展示了Deno在WebSocket实现中的便捷与强大,无需额外依赖,即可轻松搭建具备基本功能的WebSocket应用。Deno 2.0被认为是最佳的WebSocket全栈应用JS运行时,适合全栈开发者学习和使用。
|
8天前
|
前端开发 JavaScript 开发者
揭秘前端高手的秘密武器:深度解析递归组件与动态组件的奥妙,让你代码效率翻倍!
【10月更文挑战第23天】在Web开发中,组件化已成为主流。本文深入探讨了递归组件与动态组件的概念、应用及实现方式。递归组件通过在组件内部调用自身,适用于处理层级结构数据,如菜单和树形控件。动态组件则根据数据变化动态切换组件显示,适用于不同业务逻辑下的组件展示。通过示例,展示了这两种组件的实现方法及其在实际开发中的应用价值。
14 1
|
11天前
|
前端开发 UED
vue3知识点:Suspense组件
vue3知识点:Suspense组件
24 4
|
10天前
|
JavaScript 前端开发 测试技术
组件化开发:创建可重用的Vue组件
【10月更文挑战第21天】组件化开发:创建可重用的Vue组件
18 1
|
11天前
|
JavaScript 前端开发 Java
《vue3第五章》新的组件,包含:Fragment、Teleport、Suspense
《vue3第五章》新的组件,包含:Fragment、Teleport、Suspense
21 2
|
11天前
|
JavaScript 前端开发 算法
前端优化之超大数组更新:深入分析Vue/React/Svelte的更新渲染策略
本文对比了 Vue、React 和 Svelte 在数组渲染方面的实现方式和优缺点,探讨了它们与直接操作 DOM 的差异及 Web Components 的实现方式。Vue 通过响应式系统自动管理数据变化,React 利用虚拟 DOM 和 `diffing` 算法优化更新,Svelte 通过编译时优化提升性能。文章还介绍了数组更新的优化策略,如使用 `key`、分片渲染、虚拟滚动等,帮助开发者在处理大型数组时提升性能。总结指出,选择合适的框架应根据项目复杂度和性能需求来决定。