color选择组件
parent
44eb5d5491
commit
44a45247e7
@ -1,71 +1,70 @@
|
|||||||
<!--
|
|
||||||
* @Author: lide1202@hotmail.com
|
|
||||||
* @Date: 2021-4-8 11:04:24
|
|
||||||
* @Last Modified by: lide1202@hotmail.com
|
|
||||||
* @Last Modified time: 2021-4-8 11:04:24
|
|
||||||
!-->
|
|
||||||
<template>
|
<template>
|
||||||
<el-popover placement="right"
|
<el-input
|
||||||
trigger="click">
|
clearable
|
||||||
<Chrome v-model="colors"
|
v-model="colorValue"
|
||||||
@input="updateValue" />
|
placeholder="请输入颜色"
|
||||||
<el-input slot="reference"
|
|
||||||
v-model="colors.hex"
|
|
||||||
size="mini"
|
size="mini"
|
||||||
placeholder="颜色选择器">
|
@change="changeColor"
|
||||||
<template #append><i class="iconfont iconcolorSelector" /></template>
|
>
|
||||||
|
<template slot="append">
|
||||||
|
<el-color-picker
|
||||||
|
v-model="colorValue"
|
||||||
|
:predefine="predefineColors"
|
||||||
|
size="mini"
|
||||||
|
@change="changeColor"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
</el-input>
|
</el-input>
|
||||||
</el-popover>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { Chrome } from 'vue-color' // https://gitee.com/mirrors/vue-color // Photoshop Chrome
|
|
||||||
export default {
|
export default {
|
||||||
name: 'ColorPicker',
|
name: "ColorPicker",
|
||||||
components: {
|
|
||||||
Chrome,
|
|
||||||
},
|
|
||||||
model: {
|
model: {
|
||||||
prop: 'value',
|
prop: "value",
|
||||||
event: 'input',
|
event: "input"
|
||||||
},
|
},
|
||||||
props: {
|
props: {
|
||||||
value: {
|
value: {
|
||||||
type: [String],
|
type: [String],
|
||||||
default: '',
|
default: ""
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
data () {
|
data() {
|
||||||
return {
|
return {
|
||||||
colors: {
|
predefineColors: [
|
||||||
hex: '',
|
"#ff4500",
|
||||||
hsl: { h: 150, s: 0.5, l: 0.2, a: 1 },
|
"#ff8c00",
|
||||||
hsv: { h: 150, s: 0.66, v: 0.3, a: 1 },
|
"#ffd700",
|
||||||
rgba: { r: 25, g: 77, b: 51, a: 1 },
|
"#90ee90",
|
||||||
},
|
"#00ced1",
|
||||||
}
|
"#1e90ff",
|
||||||
|
"#c71585"
|
||||||
|
],
|
||||||
|
colorValue: ""
|
||||||
|
};
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
value (val) {
|
value(val) {
|
||||||
this.colors.hex = val
|
this.colorValue = val || "";
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted () {
|
mounted() {
|
||||||
this.colors.hex = this.value
|
this.colorValue = this.value;
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
updateValue (value) {
|
changeColor(val) {
|
||||||
// this.colors = value
|
this.colorValue = val || "";
|
||||||
this.$emit('input', value.hex)
|
this.$emit("input", this.colorValue);
|
||||||
this.$emit('change', value.hex)
|
this.$emit("change", this.colorValue);
|
||||||
},
|
}
|
||||||
},
|
}
|
||||||
}
|
};
|
||||||
</script>
|
</script>
|
||||||
|
<style lang="scss" scoped>
|
||||||
<style scoped lang="scss">
|
/deep/.el-color-picker--mini,
|
||||||
/deep/.el-input-group__append {
|
/deep/.el-color-picker--mini .el-color-picker__trigger {
|
||||||
width: 20px;
|
width: 23px;
|
||||||
padding: 0 5px;
|
height: 23px;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
Loading…
Reference in New Issue