zoukankan      html  css  js  c++  java
  • 前端组件化之路

    前言:

       最近在工作中发现我们前端没有一个系统的体系去支撑,产生很多不必要的代码冗余,一些公共的视图模块重复开发,导致开发效率下降,最让我郁闷的是,前端开发好的静态页面给java开发去做业务逻辑处理,会彻底的把我们开发的页面结构改的惨目忍睹。这样的形式做项目在不去想点子优化做法,真不是个合格的程序员。

    组件化形态:

              组件化形态很多种,我个人理解为2个分支:

                             1.公共组件 (单独用js封装的一个视图功能的集合体,例如:富文本编译器,时间控件...)

                             2.业务组件 (根据业务场景所定义的页面组件块:例如:数据列表展示,条件搜索)

               在上面的组件概念中继续深入定义

                              1.块组件:(块组件是一小块区域的组件化形态定义,且这块组件都存在公用性才能被提取成块组件。例如:按钮)

                              2.原子组件:(是块组件内部最小元素的定义,更直白的说就是HTML原始元素,例如<a>,<img>...)

               从上面的概述,我们把组件化抽象出2种大分类,每种分类必然都包含了2类组件形态,我这样分是参考物理领域对物质组成而设计的,构成物质的微粒有分子、原子和离子,这个解释拿到组件化概念中是这样定义的(写一个组件定义公式):

                原子组件 = 原子 ||  分子 ||  离子

                块组件 = 分子 + 原子  + 离子

                业务组件 = 块组件  + N

                公共组件 = 分子 + 原子  + 离子 +  块组件

                从原子到组件群,层级归类,提取公用形成的组件化形态展示。

    组件化的概念:

     为什么有组件化的想法出来,我个人认为,在当今前端开发过程中,框架种类太多,对应的场景应用也不同,这样就把框架束缚了,不能适应多种场景的应用开发。没有一个前端框架能“容纳百川”,怎么才能让前端开发能够效率提升,适应多种场景开发呢? 提取页面中的公共部分进行封装,重用,是独立的,不受场景的变化,依然运行流畅,功能,性能优越。业界定义这称之为“组件”,比如:富文本编译器,时间控件等,而组件化是让你在开发过程中自由的封装DOM区域,形成一个组件的方式去操作内容块的封装。还有用几段代码来呈现以下比较直观:

  • 相关阅读:
    log4j1修改DailyRollingFileAppender支持日志最大数量
    log4j1 修改FileAppender解决当天的文件没有日期后缀
    log4j生成有日期的日志文件名
    Java删除List和Set集合中元素
    Java并发编程:并发容器之ConcurrentHashMap
    Java并发编程:并发容器之CopyOnWriteArrayList
    java.util.ConcurrentModificationException解决详解
    Handshake failed due to invalid Upgrade header: null 解决方案
    web项目Log4j日志输出路径配置问题
    log4j.properties 的使用详解
  • 原文地址:https://www.cnblogs.com/kuailingmin/p/4205724.html
Copyright © 2011-2022 走看看