JS判断颜色是否为深色 阀值

前言

碰到一个有趣的项目需求,判断颜色的深浅,若为深色则设置浅色阴影;反之,设置深色阴影。

本来没有头绪,怎样从才能知晓她的深浅呢,百度一下就tmd有了结果。

// arr为用于存储rgb的三个数据
var $grayLevel = arr[0] * 0.299 + arr[1] * 0.587 + arr[2] * 0.114;

知道其原理,则可以开始实践了…

  <div id="app">
    <div :style="bgc"></div>
    <br><br>
    <button @click="testing">testing</button>
  </div>
    new Vue({
      el: '#app',
      data() {
        return {
          bgc: {
            width: '80px',
            height: '80px',
            backgroundColor: 'rgb(255,200,255)',
            margin: '10px',
            boxShadow: ''
          }
        }
      },
      methods: {
        testing() {
          var color = this.bgc.backgroundColor
          var arr = color.replace('rgb(','').replace(')','').split(',').map(Number);
          console.log(arr);
          var $grayLevel = arr[0] * 0.299 + arr[1] * 0.587 + arr[2] * 0.114;
          console.log($grayLevel);

          if ($grayLevel >= 192) {
            this.turnDarkColor(arr)
          } else {
            this.turnLightColor(arr)
          }
        },
        turnDarkColor(arr) {
          var cla = new ColorHandle();
          var hex = cla.RgbToHex(arr[0],arr[1],arr[2]);
          this.bgc.boxShadow = "10px 10px 10px 8px " + cla.getDarkColor(hex,0.6)
        },
        turnLightColor(arr) {
          var cla = new ColorHandle();
          var hex = cla.RgbToHex(arr[0],arr[1],arr[2]);
          this.bgc.boxShadow = "10px 10px 10px 8px " + cla.getLightColor(hex,0.6)
        }
      }
    })

这里需引入一个颜色转换的js文件:

附上链接

效果图如下:
在这里插入图片描述

在这里插入图片描述

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值