在vue中实现picker样式_基于vue的颜色选择器vue-color-picker

/*** author : alex* email : 961163829@qq.com*/exportdefault{props:{/*由父组件传递的默认颜色*/defaultColor:{type:String,default:"#000000"},/*目标元素,可以是input框或者按钮等*/targetElem:null},data(){return{isShowPicker:false,...
摘要由CSDN通过智能技术生成

/**

* author : alex

* email : 961163829@qq.com*/exportdefault{

props:{/*由父组件传递的默认颜色*/defaultColor:{

type:String,default:"#000000"},/*目标元素,可以是input框或者按钮等*/targetElem:null},

data(){return{

isShowPicker:false,

wheel:document.querySelector('.wheel'),

color:this.defaultColor,

containerId:"color-picker-container",

dom:{

hMarker:null,

slMarker:null,

color:null,

targetElem:null,

container:null},

radius:84,

square:100,

width:194}

},

mounted(){this.dom.container=document.querySelector('#'+this.containerId);this.dom.hMarker=document.querySelector('.h-marker');this.dom.slMarker=document.querySelector('.sl-marker');this.dom.color=document.querySelector('.color');this.dom.targetElem=document.querySelector(this.targetElem);this.init();

},

methods:{

init:function(){var self = this;

self.posInit();

self.eventBind();//Init color

self.setColor(self.color);

},

openPicker:function(){var self = this;this.isShowPicker = true;this.wheel=document.querySelector('.wheel');/*色盘打开的时候绑定点击事件*/document.addEventListener("click",self.documentClick);

},

closePicker:function(){this.isShowPicker = false;/*色盘关闭的时候解绑事件*/document.removeEventListener("click",this.documentClick);

},

eventBind:function(){var self = this;

self.dom.container.addEventListener("mousedown",self.mousedown);

},

documentClick:function(e){/*你可能不需要关闭色盘,那这个方法也是可以不需要的*/

var parents1 = this.getParents(e,this.dom.container,true);;var parents2 = this.getParents(e,this.dom.targetElem,true);if(parents1.length===0&&parents2.length===0){this.closePicker();

}

},

posInit:function(){/*色盘的位置计算*/

var target = this.dom.targetElem;var top = this.getElementViewTop(target);var left = this.getElementViewLeft(target);this.dom.container.style.position = "fixed";this.dom.container.style.top = (top)+'px';this.dom.container.style.left = (left + this.dom.targetElem.offsetWidth)+'px';

},

getElementViewLeft:function(element){/*获取元素距离视窗左部距离*/

var actualLeft =element.offsetLeft;var current =element.offsetParent;while (current !== null){

actualLeft+=current.offsetLeft;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值