原生js实现一个自定义色块的取色器颜色选择器效果代码

代码语言:html

所属分类:选择器

代码描述:原生js实现一个自定义色块的取色器颜色选择器效果代码

代码标签: js 颜色 选择器

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <style>

        .color-picker-container {
      display: inline-block;
      background: #5d5f60 none repeat scroll 0% 0%;
      border-radius: 4px;
      border: 2px solid #f8fafb;
    }
    .color-picker-container .picker-container .canvas-container {
      margin: 20px;
      position: relative;
      float: left;
      width: 200px;
      display: inline-block;
      background: #5D5F60;
    }
    .color-picker-container .picker-container .canvas-container.active {
      display: block;
    }
    .color-picker-container .picker-container .canvas-container canvas {
      cursor: crosshair;
      border-radius: 50%;
      box-shadow: 0 0 0 4px #E8E8E8;
      background: #E6D3D3;
    }
    .color-picker-container .picker-container .canvas-container .pointer {
      width: 15px;
      height: 15px;
      border: 2px solid #fff;
      border-radius: 50%;
      position: absolute;
      pointer-events: none;
      background: rgba(0, 0, 0, 0.1);
    }
    .color-picker-container .picker-container .canvas-container input {
      margin-top: 10px;
      width: 100%;
      height: 30px;
      text-align: center;
      background: #353738;
      border: 0;
      color: #fff;
    }
    .color-picker-container .picker-container .slider-container {
      width: 15px;
      float: right;
      position: relative;
      margin: 15px;
    }
    .color-picker-container .picker-container .slider-container .slider {
      width: 15px;
      height: 249px;
      background: #000;
    }
    .color-picker-container .picker-container .slider-container .pointer {
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 5px 0 5px 10px;
      border-color: transparent transparent transparent #007bff;
      position: absolute;
      left: -8px;
    }
    .color-picker-container .palletes-container {
      float: right;
      width: 275px;
    }
    .color-picker-container .palletes-container .palette {
      width: 35px;
      height: 35px;
      float: right;
      border-radius: 4px;
      margin: 5px;
      box-shadow: inset 0px 2px 1px rgba(0, 0, 0, 0.28);
      cursor: pointer;
    }
    .color-picker-container .palletes-container .palette.active {
      box-shadow: 0 0 0 3px #3F3F40;
    }
    .color-picker-container .palletes-container .palette.add {
      border: 2px dashed #bababa;
      box-shadow: inherit;
      position: relative;
    }
    .color-picker-container .palletes-container .palette.add:after {
      content: '+';
      font-size: 24px;
      color: #bababa;
      position: absolute;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0;
      text-align: center;
      line-height: 30px;
    }
    </style>
</head>

<body>
    <div id="picker"></div>

    <script>
        var ColorPicker;
    
     (function() {
    
       function insertBefore(element, before) {
         parent = before.parentNode;
         parent.insertBefore(element, before);
       }
    
       function extend(defaults, options) {
         var extended = {};
         var prop;
         for (prop in defaults) {
           if (Object.prototype.hasOwnProperty.call(defaults, prop)) {
             extended[prop] = defaults[prop];
           }
         }
         for (prop in options) {
           if (Object.prototype.hasOwnProperty.call(options, prop)) {
             extended[prop] = options[prop];
           }
         }
         return extended;
       };
    
       function hasClass(element, classname) {
         var className = " " + classname + " ";
         if ((" " + element.className + " ").replace(/[\n\t]/g, " ").indexOf(" " + classname + " ") > -1) {
           return true;
         }
         return false;
       }
    
       function removeClass(node, className) {
         node.className = node.className.replace(
           new RegExp('(^|\\s+)' + className + '(\\s+|$)', 'g'),
           '$1'
         ).replace(/ +(?= )/g, '').trim();
       }
    
       function addClass(element, className) {
         if (!hasClass(element, className)) {
           element.className += ' ' + className;
           element.className = element.className.replace(/ +(?= )/g, '').trim()
         }
       }
    
       ColorPicker = function(element, options) {
    
         this.options = extend({
           color: '#e7e7e7',
           palettes: ['#646fff', '#fffa1d', '#ffa21f', '#ff391d'],
           onUpdate: function() {}
         }, options);
    
         this.options.palettes.unshift(this.options.color);
    
         this.hex = this.options.color;
         this.rgb = this.HEXtoRGB(this.hex);
         this.hsv = this.RGBtoHSV(this.rgb[0], this.rgb[1], this.rgb[2]);
         this.dom = {};
         this.dom.container = document.createElement('div');
         this.dom.container.className = 'color-picker-container';
    
         element.appendChild(this.dom.container);
    
         this.initPicker();
    
         this.initPalettes();
       }
    
       ColorPicker.prototype.initPicker = function() {
    
         this.dom.picker = {};
         this.dom.picker.container = document.createElement('div');
         this.dom.picker.container.className = 'picker-container';
    
         this.dom.container.appendChild(this.dom.picker.container);
    
         this.dom.picker.canvas = {};
    
         this.dom.picker.canvas.container = document.createElement('div');
         this.dom.picker.canvas.container.className = 'canvas-container';
         this.dom.picker.container.appendChild(this.dom.picker.canvas.container);
    
         this.dom.picker.canvas.canvas = document.createElement('canvas');
         this.dom.picker.canvas.canvas.className = 'canvas';
    
         this.dom.picker.canvas.pointer = document.createElement('div');
         this.dom.picker.canvas.pointer.className = 'pointer';
    
         var ctx = this.dom.picker.canvas.canvas.getContext('2d'),
           image = new Image,
           $this = this,
           dragging = false;
    
         this.dom.picker.canvas.canvas.setAttribute('width', 200);
         this.dom.picker.canvas.canvas.setAttribute('height', 200);
         this.dom.picker.canvas.container.appendChild(this.dom.picker.canvas.canvas);
         this.dom.picker.canvas.container.appendChild(this.dom.picker.canvas.pointer);
    
         // image.src = 'images/wheel copy.png';
         image.src = '.........完整代码请登录后点击上方下载按钮下载查看

网友评论0