在HTML中,根据覆盖的背景区域的亮度来改变文本颜色?
可以使用以下代码片段根据其父背景颜色覆盖像素的平均亮度来更改文本颜色。
var rgb = [255, 0, 0]; setInterval(display, 1000); function display() { rgb[0] = Math.round(Math.random() * 255); rgb[1] = Math.round(Math.random() * 255); rgb[2] = Math.round(Math.random() * 255); var d = Math.round(((parseInt(rgb[0]) * 299) + (parseInt(rgb[1]) * 587) + (parseInt(rgb[2]) * 114)) / 1000); // for foregound var f = (d> 125) ? 'black' : 'white'; // for background var b = 'rgb(' + rgb[0] + ',' + rgb[1] + ',' + rgb[2] + ')'; $('#box').css('color', f); $('#box').css('background-color', b); } <scriptsrc = https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js></script> <div id = box> Demo</div>
以下是 CSS –
#box { width: 300px; height: 300px; }
以上就是在HTML中,根据覆盖的背景区域的亮度来改变文本颜色?的详细内容,更多请关注双恒网络其它相关文章!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。