首頁 > web前端 > html教學 > 在HTML中,根據覆蓋的背景區域的亮度來改變文字顏色?

在HTML中,根據覆蓋的背景區域的亮度來改變文字顏色?

PHPz
發布: 2023-08-28 13:29:02
轉載
675 人瀏覽過

在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中,根據覆蓋的背景區域的亮度來改變文字顏色?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板