最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Vue UI组件库对比与选择

    正文概述 掘金(俄小发)   2021-03-05   663

    主流组件库对比

    PC端

    UI组件库名github star是否可自定义主题是否支持vue3发布时间稳定性贡献者
    ElementUI49.3k可自定义支持,beta版本,3版本官网,3版本github2016-08,4年半长期支持,最新两个版本间隔时间1个半月饿了么Vuetify29.7k可自定义开发阶段,计划2021Q3发布2016-12,4年3个月长期支持,更新频率为半个月Vuetify公司iview/View UI23.7k可自定义不支持2017-02,4年长期支持,更新频率为3个月北京视图更新科技有限公司Ant Design13.8k可自定义支持,3版本2018-04,3年长期支持,更新频率为半个月蚂蚁金服Veui789可自定义不支持2017-07,3年半长期支持,更新频率为半个月百度

    移动端

    UI组件库名github star是否可自定义主题是否支持vue3发布时间稳定性贡献者
    Vant16.8k可自定义支持3版本2017-04,4年长期支持,更新频率为半个月有赞前端团队cube ui8.6k可自定义不支持2017-11,3年3个月暂无维护,最后发布时间为2020-04滴滴mint-ui16.3k暂不支持不支持2016-09,4年半暂无维护,最后发布时间为2017-04饿了么前端团队vux17.4k可简单配置不支持2016-03,5年暂无维护,最后发布时间为2019-04个人

    重点介绍『定制主题』

    ElementUI

    demo地址

    1. 仅替换主题色

    在线主题生成工具生成对应颜色主题,下载主题,将样式文件加入到项目中,在引入element的地方引入样式文件即可

    import '@/assets/style/theme/index.css'
    

    2. 改变 SCSS 变量

    在项目中改变 Element Plus 的样式变量。新建一个SCSS样式文件,例如 element-variables.scss

    3. 命令行主题工具

    安装element-theme,element-theme-chalk,通过et调用工具,执行-i初始化变量文件,生成变量文件element-variables.scss

    修改对象变量后,编译主题,将主题编译输出到指定目录。使用自定义主题的方式进行引入使用。

    4. 使用自定义主题

    1. import引入对应css文件即可
    2. 搭配babel-plugin-component插件按需引入组件主题

    babel-plugin-import和babel-plugin-component的区别

    module.exports = {
      presets: [
        '@vue/cli-plugin-babel/preset'
      ],
      plugins: [
        [
          'component',
          {
            libraryName: 'element-plus',
            styleLibraryName: '~src/theme' // 本地样式目录
          }
        ]
      ]
    }
    

    或搭配babel-plugin-import插件按需引入组件主题

    module.exports = {
      presets: [
        '@vue/cli-plugin-babel/preset'
      ],
      plugins: [
        ['import', {
          libraryName: 'element-plus',
          libraryDirectory: 'es',
          customStyleName: name => {
            return `theme/${name}.less`
          }
        }]
      ]
    }
    
    

    Ant design

    1. 通过modifyVars来覆盖less变量

    vue.config.js

    module.exports = {
      css: {
        loaderOptions: {
          less: {
            lessOptions: {
              // 更改变量
              modifyVars: {
                'blue-base': '#1DA57A',
                'primary-color': '#1DA57A'
                'border-radius-base': '3px'
              },
              javascriptEnabled: true
            }
          }
        }
      }
    }
    

    babel.config.js

    module.exports = {
      presets: [
        '@vue/cli-plugin-babel/preset'
      ],
      plugins: [
        [
          'import',
          {
            libraryName: 'ant-design-vue',
            libraryDirectory: 'es',
            style: true
          }
        ]
      ]
    }
    

    2. 配置less文件

    @import '~ant-design-vue/dist/antd.less'; // 引入官方提供的 less 样式入口文件
    @import 'your-theme-file.less'; // 用于覆盖上面定义的变量
    

    3. 自定义主题包

    主题包目录:

    - theme
    	- alert.less
    	- button.less
    	- ....组件对应less文件
    

    发布theme包到npm

    引用主题包:

    babel.config.js

    module.exports = {
      presets: [
        '@vue/cli-plugin-babel/preset'
      ],
      plugins: [
        [
          'import',
          {
            libraryName: 'ant-design-vue',
            libraryDirectory: 'es',
            // 自定义样式包
            customStyleName: name => {
              // theme为自定义主题包名,按需加载对应组件样式
              return `theme/${name}.less`
            }
          }
        ]
      ]
    }
    
    

    Vant

    1. 通过modifyVars来覆盖less变量

    vue.config.js

    module.exports = {
      css: {
        loaderOptions: {
          less: {
            lessOptions: {
              // 更改变量
              modifyVars: {
                // 直接覆盖变量
                'button-primary-background-color': 'red',
                'text-color': '#111',
                'border-color': '#eee'
                // 或者可以通过 less 文件覆盖(文件路径为绝对路径)
                hack: 'true; @import "@/theme/variables.less";'
              },
              javascriptEnabled: true
            }
          }
        }
      }
    }
    

    2. 自定义主题包

    主题包目录:

    - theme
    	- alert.less
    	- button.less
    	- ....组件对应less文件
    

    发布theme包到npm

    引用主题包:

    babel.config.js

    module.exports = {
      presets: [
        '@vue/cli-plugin-babel/preset'
      ],
      plugins: [
        ['import', {
          libraryName: 'vant',
          libraryDirectory: 'es',
          // style: (name) => `${name}/style/less`
          customStyleName: name => {
            return `theme/${name}.less`
          }
        }]
      ]
    }
    

    总结

    均可通过babel-plugin-importcustomStyleName,配置主题包,进行按需加载组件和对应样式文件

    第三方库或自研

    • 自研需要大量的人力成本和时间成本,需要考虑后期的长期维护和稳定性
    • 第三方库考虑其稳定性和维护性,可开发自定义主题进行定制化开发

    参考文档

    • www.zhihu.com/question/29…
    • segmentfault.com/a/119000002…

    下载网 » Vue UI组件库对比与选择

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元