zoukankan      html  css  js  c++  java
  • 我所知道的前端组件化与模块化

    序言:组件化?模块化?这都是什么鬼?这是最初看到这2个新名词的反应。随着时间的推移,似乎、可能、大概明白了一点,于是想说说自己的理解(仅仅是自己的理解)

    一、组件化

    忘记什么时候看到这个词的了,由于用过bootstrap的前提下(一下简称BS),当时第一反应是这样的,组件化不就是像BS那样把html拆分为:按钮组、栅格系统、导航组等等N多个组件,用的时候直接用BS提供class不就行了吗?
    当然简单可以这么理解,但是跟深层次的理解应该是这样的,如你看到的一个html源码可能是这样的:

    <body >
        <top-header></top-header>
        <common-content></common-content>
        <top-footer></top-footer>
    </body>

    很多人咋一看可能回想,这tm是html标签吗?当然不是,只是自定义的组件标签,通过第三方去处理,好处就是互相不影响,用谁放谁,不用拿走,维护起来和多人协作更方便。

    二、模块化

    前端模块化更确切的说应该是javascript的模块化,其实就是一些功能以及业务逻辑的封装,比如之前一个小例子:鼠标悬停出现下拉框与鼠标悬停切换(具体参看之前一篇:如何巧妙的用面向对象封装常用效果

    function Overitem(option){
        this.init(option);
    }
    Overitem.prototype={
        init:function(option){
            var _self=this;
            _self.btn=document.getElementById(option.btn)||'';
            _self.item=document.getElementById(option.item)||'';
            _self.addclassname=option.addclass;
            //2.0 绑定事件
            _self.btn.onmouseover=_self.showitem.bind(_self);
            _self.btn.onmouseout=_self.hideitem.bind(_self);
        },
        //2.1 定义事件
        showitem:function () {
            //如何让this指向new Overitem;,在调用的时候用bind把this绑定上去
            this.btn.className=this.addclassname;
            this.item.style.display='block';
        },
        hideitem:function () {
            //如何让this指向new Overitem;,在调用的时候用bind把this绑定上去
            this.btn.className='';
            this.item.style.display='none';
        }
    };
    function Tabitem(option){
        this.init(option);
    }
    Tabitem.prototype={
        init:function(option){
            var _self=this;
            _self.btn=document.getElementsByClassName(option.btn)||'';
            _self.item=document.getElementsByClassName(option.item)||'';
            for(var i=0;i<_self.btn.length;i++){
                _self.btn[i].index=i;
                _self.btn[i].onmouseover=function(){
                    for(var j=0;j<_self.item.length;j++){
                        _self.btn[j].className=option.btn;
                        _self.item[j].className=option.item;
                    }
                    _self.btn[this.index].className=option.btn+' '+option.btnaddclass;
                    _self.item[this.index].className=option.item+' '+option.itemaddclass;
                    //console.log(this);
                    //console.log(_self);
                };
            }
        }
    };

    这就是2个简单的功能模块,用谁new谁互不干扰,即使有n多个,与外界的桥梁就是所传的参数。说的不够仔细,但或多或少能理解一点- -

    想了解更多请移步:组件化模块化

  • 相关阅读:
    Java自学-多线程 常见线程方法
    Java自学-多线程 启动一个线程
    Java自学-Lambda 聚合操作
    Java自学-Lambda 方法引用
    Java自学-Lambda 概念
    Java自学-泛型 泛型转型
    Java自学-泛型 通配符
    Java自学-泛型 支持泛型的类
    <VCC笔记> 关于Assertion
    <VCC笔记>VCC简介与安装
  • 原文地址:https://www.cnblogs.com/-walker/p/6611649.html
Copyright © 2011-2022 走看看