3328350766
6 天以前 761eb03d6b3bebd0b197179564c84d89d3d12a0d
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
/** * @Description: 渐变色配置 * @author liu.shiyi * @date 2023/4/13 16:01 */
<template>
  <div class="bs-gradual-wrap">
    <el-color-picker
      v-model="startColor"
      class="bs-el-color-picker"
      show-alpha
      popper-class="bs-el-color-picker"
    />
    <div class="el-icon-right" />
    <el-color-picker
      v-model="endColor"
      class="bs-el-color-picker"
      show-alpha
      popper-class="bs-el-color-picker"
    />
  </div>
</template>
 
<script>
export default {
  name: 'GradualSetting',
  model: {
    prop: 'colors',
    event: 'change'
  },
  props: {
    colors: {
      type: Array,
      default: ()=>([])
    }
  },
  data () {
    return {
      startColor: '', // 初始颜色
      endColor: '', // 终止颜色
          }
  },
  computed: {
  },
  watch: {
    colors(){
      this.init()
    },
    startColor () {
      this.colorChange()
    },
    endColor () {
      this.colorChange()
    }
  },
  mounted () {
    this.init()
  },
  methods: {
    init () {
      this.startColor = this.colors[0]
      this.endColor = this.colors[1]
    },
    colorChange (val) {
      const colorsValue = (this.startColor||this.endColor)?[this.startColor,this.endColor]:[]
      this.$emit('change', colorsValue)
    }
  }
}
</script>
 
<style lang="scss" scoped>
 
  .bs-gradual-wrap{
    width: 100%;
    display: flex;
    align-items: center;
    .el-icon-right{
      width: 40px;
      text-align: center;
    }
  }
 
</style>