javascript - 在 Javascript 中获取 Bootstrap 当前的主题颜色

标签 javascript jquery css bootstrap-4

我的目标是使用 chart.js 创建图表,使用与当前选择的 Bootstrap 4 主题相匹配的颜色(网站有多个主题可用)

我目前的策略是在页面上使用各种颜色的徽章:

  <div id="color-example-badge-primary" class="badge badge-primary" ></div >
  <div id="color-example-badge-warning" class="badge badge-warning" ></div >
  <div id="color-example-badge-danger" class="badge badge-danger" ></div >
  <div id="color-example-badge-secondary" class="badge badge-secondary" ></div >
  <div id="color-example-badge-light" class="badge badge-light" ></div >
  <div id="color-example-badge-success" class="badge badge-success" ></div >
  <div id="color-example-badge-info" class="badge badge-info" ></div >
  <div id="color-example-badge-dark" class="badge badge-dark" ></div >

然后使用 jQuery 将背景颜色拉入数组:

var themeColors = [$("#color-example-badge-primary").css('backgroundColor'),
                   $("#color-example-badge-warning").css('backgroundColor'),
                   $("#color-example-badge-danger").css('backgroundColor'),
                   $("#color-example-badge-secondary").css('backgroundColor'),
                   $("#color-example-badge-light").css('backgroundColor'),
                   $("#color-example-badge-success").css('backgroundColor'),
                   $("#color-example-badge-info").css('backgroundColor'),
                   $("#color-example-badge-dark").css('backgroundColor')
];

然后我可以将此数组提供给 chart.js 以创建具有主题颜色的图表。

是否有更好的方法使用 Javascript 从 CSS 获取当前主题颜色?或者如果不创建 DOM 元素并测试它的背景颜色就没有办法吗?

如果有一种无需处理 DOM 元素即可使用 Javascript 获取 CSS 规则的简单方法,那就太好了。

最佳答案

Bootstrap 也将其主题颜色存储在 :root 元素上的 CSS 变量中。

更合适的方法是使用 getComputedStyle() 提取这些颜色和 getPropertyValue('--variable')

const style = getComputedStyle(document.body);
const theme = {
  primary: style.getPropertyValue('--primary'),
  secondary: style.getPropertyValue('--secondary'),
  success: style.getPropertyValue('--success'),
  info: style.getPropertyValue('--info'),
  warning: style.getPropertyValue('--warning'),
  danger: style.getPropertyValue('--danger'),
  light: style.getPropertyValue('--light'),
  dark: style.getPropertyValue('--dark'),
};

console.log(theme);
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">

<div class="container"></div>

现在您可以通过 JavaScriptjQuery 使用这些颜色,如下所示

element.style.backgroundColor = theme.primary; // Javascript
$(element).css('background-color', theme.primary); // jQuery

对于 Bootstrap 5

Bootstrap 5 将其重命名为属性,以便将上述代码与 Bootstrap 5 一起使用,请参见下面的示例

const style = getComputedStyle(document.body);
const theme = {
  primary: style.getPropertyValue('--bs-primary'),
  secondary: style.getPropertyValue('--bs-secondary'),
  success: style.getPropertyValue('--bs-success'),
  info: style.getPropertyValue('--bs-info'),
  warning: style.getPropertyValue('--bs-warning'),
  danger: style.getPropertyValue('--bs-danger'),
  light: style.getPropertyValue('--bs-light'),
  dark: style.getPropertyValue('--bs-dark'),
};

console.log(theme);
<!-- JavaScript Bundle with Popper -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0/dist/js/bootstrap.bundle.min.js" integrity="sha384-A3rJD856KowSb7dwlZdYEkO39Gagi7vIsF0jrRAoQmDKKtQBHUuLZ9AsSv4jD4Xa" crossorigin="anonymous"></script>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-gH2yIJqKdNHPEq0n4Mqa/HGKIhSkIHeL5AyhkYV8i59U5AR6csBvApHHNl/vI1Bx" crossorigin="anonymous">

<div class="container"></div>

关于javascript - 在 Javascript 中获取 Bootstrap 当前的主题颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52603754/

相关文章:

html - 包裹在选择框中 - Firefox 的问题

css - 我网站上某些图片的分辨率太低

javascript - 将变量从函数传递到 if 语句

javascript - Mootools - Fx.Tween 与 Fx.Morph

javascript - 查找第三个父级 jQuery

javascript - 使用从其他 JSON 获取的字符串引用 JSON 变量

javascript - 翻转图像和 HTML5 Canvas 中绘制的线条

javascript - 使用 setinterval 不断点击 id

javascript - 这个 CSS 渲染是如何阻塞的?

javascript - 通过 document.getElementbyid() 使用 javascript 进行用户名验证