用javascript获取任意颜色的更亮或更暗颜色值示例代码
前言
本文主要给大家介绍的是关于利用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); |