• 定制主题
    • 变量覆盖(推荐)
    • 通过安装工具修改

    定制主题

    iView 默认提供了一套 UI 主题,并且可以在一定程度上定制新主题,以满足业务和品牌上的多样化视觉需求。

    iView 的样式是基于 Less 进行开发的,默认以前缀 .ivu- 作为命名空间,并且定义了一套样式变量,定制主题,就是编辑这个变量列表。
    定制主题 - 图1

    变量覆盖(推荐)

    如果你的项目使用了 webpack 工程,可以通过变量覆盖的方式来实现主题定制。

    首先在项目中先建一个目录,比如 my-theme,然后在 my-theme 下建立一个 less 文件 index.less,并写入下面内容:

    1. @import '~iview/src/styles/index.less';
    2. // Here are the variables to cover, such as:
    3. @primary-color: #8c0776;

    完整的变量列表可以查看 默认样式变量。

    然后在入口文件 main.js 内导入这个 less 文件即可:

    1. import Vue from 'vue';
    2. import iView from 'iview';
    3. import '../my-theme/index.less';
    4. Vue.use(iView);

    通过安装工具修改

    如果没有使用 webpack,可以用我们提供的工具 iview-theme 来编译。

    首先需要安装主题生成工具,从 npm 全局或在项目中局部安装,以全局安装为例:

    1. npm install iview-theme -g

    然后在业务工程里新建一个目录,用来存放主题文件,使用下面的命令初始化主题,这时会从 iView 仓库拉取最新的样式文件:

    1. iview-theme init my-theme

    如需拉取指定版本号的 iView,使用下面的命令。(实际运行下面命令时,需将 xxx 替换成项目所使用的 iView 版本,如 “ v2.14.3 ”)

    1. iview-theme init my-theme xxx

    最后编辑 my-theme/custom.less 文件,用命令编译即可:

    1. cd my-theme
    2. iview-theme build -o dist/

    最终会在指定的目录下编译为 iview.css 的文件,只需在入口处引用它就可以了,比如在 main.js 文件:

    1. import Vue from 'vue';
    2. import iView from 'iview';
    3. import '../my-theme/dist/iview.css';
    4. Vue.use(iView);

    注意:在更新 iView 后,应该重新拉取。