当前位置:   article > 正文

vue2+element ui制定义主题色_:export { theme: $--color-primary; }

:export { theme: $--color-primary; }

添加插件

npm i element-ui -S

新建一个scss 文件elementui-variables.scss
大
文件elementui-variables.scss 代码

/* theme color */
$--color-primary: #4593ff;//默认主题色
$--color-success: #13ce66;
$--color-warning: #FFBA00;
$--color-danger: #ff4949;
// $--color-info: #1E1E1E;

$--button-font-weight: 400;

// $--color-text-regular: #1f2d3d;

$--border-color-light: #dfe4ed;
$--border-color-lighter: #e6ebf5;

$--table-border:1px solid #dfe6ec;

/* icon font path, required */
$--font-path: '~element-ui/lib/theme-chalk/fonts';

// @import "~element-ui/packages/theme-chalk/src/index";

:export {
  theme: $--color-primary;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

没有安装scss,先装好scss

main.js引入element-ui 和上面创建的scss文件

import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import './common/css/elementui-variables.scss';//主题文件
  • 1
  • 2
  • 3

如果这里引入elementui-variables.scss报错启动不了项目,检查一下这里把它注释或者删掉
在这里插入图片描述
如果没什么异常,咋们参考一下使用别人写的组件(这里的组件是拷贝一个博主的)
创建theme_picker组件

<template>
    <el-color-picker
      v-model="theme"
      :predefine="['#409EFF', '#67C23A', '#E6A23C', '#f5222d', '#11a983', '#13c2c2', '#6959CD', '#434f5d', ]"
      class="theme-picker"
      popper-class="theme-picker-dropdown" title="换肤"
    />
</template>

<script>
  const version = require('element-ui/package.json').version // element-ui version from node_modules
  const ORIGINAL_THEME = '#409EFF' // default color

  export default {
    name:"theme_picker",
    data() {
      return {
        chalk: '', // content of theme-chalk css
        theme: ''
      }
    },
    computed: {
      defaultTheme() {
        return this.$store.state.web_color;
      }
    },
    watch: {
      defaultTheme: {
        handler: function(val, oldVal) {
          this.theme = val;
          this.update_web_color(val)
        },
        immediate: true
      },
      theme(newVal,oldVal){
       this.$emit("change",newVal);
      }
    },

    methods: {
      update_web_color(color){
        var that=this;
        //异步函数去执行
        async function theme(val) {
          const oldVal = that.chalk ? that.theme : ORIGINAL_THEME
          if (typeof val !== 'string') return
          const themeCluster = that.getThemeCluster(val.replace('#', ''))
          const originalCluster = that.getThemeCluster(oldVal.replace('#', ''))
          // console.log(themeCluster, originalCluster)

          const $message = that.$message({
            message: '更换主题中...',
            customClass: 'theme-message',
            type: 'success',
            duration: 0,
            iconClass: 'el-icon-loading'
          })

          const getHandler = (variable, id) => {
            return () => {
              const originalCluster = that.getThemeCluster(ORIGINAL_THEME.replace('#', ''))
              const newStyle = that.updateStyle(that[variable], originalCluster, themeCluster)

              let styleTag = document.getElementById(id)

              if (!styleTag) {
                styleTag = document.createElement('style')
                styleTag.setAttribute('id', id)

                document.head.appendChild(styleTag)
                //document.getElementsByTagName('style')[0].insertBefore(styleTag, null)
              }
              styleTag.innerText = newStyle
            }
          }

          if (!that.chalk) {
            const url = `https://unpkg.com/element-ui@${version}/lib/theme-chalk/index.css`
            await that.getCSSString(url, 'chalk')
          }

          const chalkHandler = getHandler('chalk', 'chalk-style')

          chalkHandler()

          const styles = [].slice.call(document.querySelectorAll('style'))
            .filter(style => {
              const text = style.innerText
              return new RegExp(oldVal, 'i').test(text) && !/Chalk Variables/.test(text)
            })
          styles.forEach(style => {
            const { innerText } = style
            if (typeof innerText !== 'string') return
            style.innerText = that.updateStyle(innerText, originalCluster, themeCluster)
          })
          $message.close()
        };
        //调用
        theme(color);
      },

      updateStyle(style, oldCluster, newCluster) {
        let newStyle = style
        oldCluster.forEach((color, index) => {
          newStyle = newStyle.replace(new RegExp(color, 'ig'), newCluster[index])
        })
        return newStyle
      },

      getCSSString(url, variable) {
        return new Promise(resolve => {
          const xhr = new XMLHttpRequest()
          xhr.onreadystatechange = () => {
            if (xhr.readyState === 4 && xhr.status === 200) {
              this[variable] = xhr.responseText.replace(/@font-face{[^}]+}/, '')
              resolve()
            }
          }
          xhr.open('GET', url)
          xhr.send()
        })
      },

      getThemeCluster(theme) {
        const tintColor = (color, tint) => {
          let red = parseInt(color.slice(0, 2), 16)
          let green = parseInt(color.slice(2, 4), 16)
          let blue = parseInt(color.slice(4, 6), 16)

          if (tint === 0) { // when primary color is in its rgb space
            return [red, green, blue].join(',')
          } else {
            red += Math.round(tint * (255 - red))
            green += Math.round(tint * (255 - green))
            blue += Math.round(tint * (255 - blue))

            red = red.toString(16)
            green = green.toString(16)
            blue = blue.toString(16)

            return `#${red}${green}${blue}`
          }
        }

        const shadeColor = (color, shade) => {
          let red = parseInt(color.slice(0, 2), 16)
          let green = parseInt(color.slice(2, 4), 16)
          let blue = parseInt(color.slice(4, 6), 16)

          red = Math.round((1 - shade) * red)
          green = Math.round((1 - shade) * green)
          blue = Math.round((1 - shade) * blue)

          red = red.toString(16)
          green = green.toString(16)
          blue = blue.toString(16)

          return `#${red}${green}${blue}`
        }

        const clusters = [theme]
        for (let i = 0; i <= 9; i++) {
          clusters.push(tintColor(theme, Number((i / 10).toFixed(2))))
        }
        clusters.push(shadeColor(theme, 0.1))
        return clusters
      }
    }
  }
</script>

<style>
  .theme-picker {
    float: left;
    margin-top: 15px;
  }

  .theme-message,
  .theme-picker-dropdown {
    z-index: 99999 !important;
  }

  .theme-picker .el-color-picker__trigger {
    height: 26px !important;
    width: 26px !important;
    padding: 2px;
  }



  .theme-picker-dropdown .el-color-dropdown__link-btn {
    display: none;
  }
</style>

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195

注意这里有个vuex 的使用
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
ui引入样式先后顺序的原因 ,这里document.head.appendChild(styleTag)不行的话,可以尝试使用document.getElementsByTagName(‘style’)[0].insertBefore(styleTag,null),这两者切换使用尝试一下

document.head.appendChild(styleTag)
//document.getElementsByTagName(‘style’)[0].insertBefore(styleTag,null)

使用组件
在这里插入图片描述
这里回调触发函数根据需求,这里更新vuex值,这里缓存也存到颜色值
在这里插入图片描述

看一下成果
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
如果是制定义的组件的话,直接绑定样式:style="{}"来获取vuex里面的值

这里vuex 还写了一个获取主题色的透明度,写在getters节点里面

getters:{
    /**
     *主题色透明度获取
     * @param opacity 透明度
     * @returns {string}
     */
    web_color_opacity:state => {
      return function (opacity) {
        return "rgba(" + parseInt("0x" + state.web_color.slice(1, 3)) + "," + parseInt("0x" +  state.web_color.slice(3, 5)) + "," + parseInt("0x" + state.web_color.slice(5, 7)) + "," + opacity + ")";
      }
    },
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

简单粗暴直接使用
在这里插入图片描述

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号