Vue颜色选择器实现(两种方法)

简介: Vue颜色选择器实现(两种方法)

前言


本文讲述两种颜色选择器的实现方式。


别划走,最后有完整源代码。


第一种:@input和input[type=color]实现下述效果。



第二种:利用colors颜色数组、:style和v-for实现下列效果。





提示:以下是本篇文章正文内容,下面案例可供参考


一、颜色选择器(input[type=color]实现)


新建html文件并且导入vue.js


<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <script src="./js/vue.js"></script>
  </div>
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script>
</script>
</body>
</html>


Vue导入成功测试代码实现

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <script src="./js/vue.js"></script>
  <div id="app">
    {{test}}
  </div>
  </div>
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  <script>
    new Vue({
      el:"#app",
      data:{
        test:"Vue导入成功"
      }
    })
  </script>
<script>
</script>
</body>
</html>



实现过程与代码介绍


结构层


一个div块装颜色效果,一个input[type=color],一个按钮控制input是否消失。如下图所示。




<div id="app">
    <div class="overlay" :style="{backgroundColor:colorSelected}" @click="picker=!picker"></div>
    <div v-show="picker">
      <input type="color" :value="colorSelected" @input="selectColors($event)">
      <button @click="picker=false">ok</button>
    </div>
  </div>

样式层

样式就用到一个,设置div背景宽高

<style>
      .overlay{
        width:100px;
        height:100px;
      }
    </style>


js层


data数据


input颜色选择器需要用到一个参数来保存16进制颜色

颜色选择器显示隐藏还需要有一个boolean参数做判断用

data:{
        colorSelected:"#000000",
        picker:false
      },



methods方法


输入框显示隐藏也可以用methods方法下实现,在这里我结构层用@click=“picker=!picker”实现的。

唯一的方法实现是用@input实时获取value值得变换并更新到colorSelected数据中,利用的是event.target.value来进行值调用。


methods:{
        selectColors(event){
          this.colorSelected=event.target.value
        }
      }



完整代码


<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
    <style>
      .overlay{
        width:100px;
        height:100px;
      }
    </style>
  </head>
  <script src="./js/vue.js"></script>
  <div id="app">
    <div class="overlay" :style="{backgroundColor:colorSelected}" @click="picker=!picker"></div>
    <div v-show="picker">
      <input type="color" :value="colorSelected" @input="selectColors($event)">
      <button @click="picker=false">ok</button>
    </div>
  </div>
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  <script>
    new Vue({
      el:"#app",
      data:{
        colorSelected:"#000000",
        picker:false
      },
      methods:{
        selectColors(event){
          this.colorSelected=event.target.value
        }
      }
    })
  </script>
<script>
</script>
</body>
</html>


二、颜色选择器(colors数组实现)


1.完整代码

代码如下:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>颜色选择器</title>
    <style scoped>
    .color-picker {
      display: flex;
      flex-direction: column;
      align-items: center;
    }
    .color-box {
      width: 100px;
      height: 100px;
      margin-top: 20px;
    }
    .color-options {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      margin-top: 20px;
    }
    .color-option {
      width: 30px;
      height: 30px;
      margin: 5px;
      border-radius:50%;
    }
    .color-option.active {
      border: 2px solid #FFFFFF;
    }
    </style>
  </head>
  <body>
    <div id="app">
      <div class="color-picker">
        <div class="color-box" :style="{ backgroundColor: selectedColor }"></div>
        <div class="color-options">
          <div v-for="(color, index) in colors" :key="index" 
            class="color-option" :style="{ backgroundColor: color }"
            @click="selectColor(color)"
            :class="{ active: color === selectedColor }"></div>
        </div>
      </div>
    </div>
    <script src="../vue.js"></script>
    <script>
      new Vue({
        el:"#app",
        data() {
          return {
            colors: ['#F44336', '#E91E63', '#9C27B0', '#673AB7', '#3F51B5', '#2196F3',
                     '#03A9F4', '#00BCD4', '#009688', '#4CAF50', '#8BC34A', '#FFEB3B',
                     '#FFC107', '#FF9800', '#FF5722', '#795548', '#9E9E9E', '#607D8B'],
            selectedColor: '#F44336',
          };
        },
        methods: {
          selectColor(color) {
            this.selectedColor = color;
            this.$emit('color-selected', color);
          }
        }
      })
    </script>
  </body>
</html>



相关文章
|
2天前
|
JavaScript
|
1天前
|
存储 缓存 JavaScript
vue代码优化方案
【7月更文挑战第13天】 **Vue.js 优化要点:** 分解大组件以提高复用性和加载速度;利用计算属性与侦听器优化数据处理;使用Object.freeze()减少响应式数据;借助Vuex或Composition API管理状态;实现虚拟滚动和无限加载提升长列表性能;路由懒加载减少初始加载时间;用Vue DevTools检测性能瓶颈;定期代码审查与重构;应用缓存策略;遵循最佳实践与团队规范,提升应用整体质量。
10 2
|
4天前
|
JavaScript 前端开发
【vue】 el-table解决分页不能筛选全部数据的问题
【vue】 el-table解决分页不能筛选全部数据的问题
15 4
|
4天前
|
JavaScript
【vue】 vue2 监听滚动条滚动事件
【vue】 vue2 监听滚动条滚动事件
10 1
|
4天前
|
JavaScript 定位技术
【天地图】vue 天地图 T is not defined
【天地图】vue 天地图 T is not defined
15 1
|
4天前
|
JavaScript
【vue】el-dialog 内的tinymce弹窗被遮挡的解决办法 及 tinymce打开弹出菜单后直接关闭对话组件,导致该弹出菜单残留
【vue】el-dialog 内的tinymce弹窗被遮挡的解决办法 及 tinymce打开弹出菜单后直接关闭对话组件,导致该弹出菜单残留
16 6
|
9天前
|
数据采集 JavaScript 前端开发
Vue框架的优缺点是什么
【7月更文挑战第5天】 Vue框架:组件化开发利于重用与扩展,响应式数据绑定简化状态管理;学习曲线平缓,生态系统丰富,集成便捷,且具性能优化手段。缺点包括社区规模相对小,类型支持不足(Vue 3.x改善),路由和状态管理需额外配置,SEO支持有限。随着发展,部分缺点正被克服。
19 1
|
9天前
|
JavaScript
Vue卸载eslint的写法,单独安装eslint,单独卸载eslint
Vue卸载eslint的写法,单独安装eslint,单独卸载eslint
|
9天前
|
JavaScript
青戈大佬安装Vue,无Eslint安装版,vue2安装,vue2无eslint,最简单配置Vue安装资料
青戈大佬安装Vue,无Eslint安装版,vue2安装,vue2无eslint,最简单配置Vue安装资料
|
4天前
|
JavaScript 前端开发
【vue】 Tinymce 数据 回显问题 | 第一次正常回显后面,显示空白bug不能编辑
【vue】 Tinymce 数据 回显问题 | 第一次正常回显后面,显示空白bug不能编辑
11 0