全国统一服务热线:400-633-9193

用javascript获取任意颜色的更亮或更暗颜色值示例代码

    网络     2017-08-31    1171

前言

本文主要给大家介绍的是关于利用javascript获取任意颜色更亮或更暗颜色值的相关内容,下面话不多说,来一起看看详细的介绍:

预处理CSS,比如Sass和less可以通过设定一个特定值,让任何颜色变得更亮或者更暗。但是在javascript中却没有这种方法。下面这个方法能在javascript中得到一个更亮或者更暗的值,通过一个给定的十六进制颜色值(比如#F06D06,或者没有#)

示例代码


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

function LightenDarkenColor(col, amt) {

  

 var usePound = false;

  

 if (col[0] == "#") {

 col = col.slice(1);

 usePound = true;

 }

  

 var num = parseInt(col,16);

  

 var r = (num >> 16) + amt;

  

 if (r > 255) r = 255;

 else if (r < 0) r = 0;

  

 var b = ((num >> 8) & 0x00FF) + amt;

  

 if (b > 255) b = 255;

 else if (b < 0) b = 0;

  

 var g = (num & 0x0000FF) + amt;

  

 if (g > 255) g = 255;

 else if (g < 0) g = 0;

  

 return (usePound?"#":"") + (g | (b << 8) | (r << 16)).toString(16);

  

}

1

2

3

4

5

// Lighten

var NewColor = LightenDarkenColor("#F06D06", 20);

 

// Darken

var NewColor = LightenDarkenColor("#F06D06", -20);


  分享到:  
0.3146s