变浅/变暗

CSS预处理器Sass和Less可以采用任何颜色并将其darken()lighten()减小特定值。 但是JavaScript中没有内置这种功能。 此函数以十六进制格式(即,#F06D06,带有或不带有哈希值)获取颜色,并使用值使它们变亮或变暗。

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);
  
}

用法

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

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

演示版

看笔
Chris Coyier ( @chriscoyier ) 在JavaScript中进行颜色更改
在CodePen上 。

翻译自: https://css-tricks.com/snippets/javascript/lighten-darken-color/

你可能感兴趣的:(变浅/变暗)