css - 回退到本地 bootstrap 4 css 文件

标签 css bootstrap-4 fallback

这个答案:https://stackoverflow.com/a/26198380/4370354不幸的是,即使在最后尝试了 André Rocha 的回答之后,它似乎也不适用于 BS4,所以这是我的问题:

我正在尝试通过 CDN 加载 bootstrap 4,但有一个本地 CSS 文件的后备,以防万一。

下面的代码导致 bootstrap 4 css 文件被加载两次,但我希望它只加载一次。

这是我所拥有的(与上面的答案几乎相同)CSS文件的回退功能在最后:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <!-- Bootstrap 4.1.1 CSS CDN -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css">
    <title>Home | phpMIDAS viewer</title>
  </head>
  <body>
    <!-- jQuery 3.3.1 CDN -->
    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"></script>
    <!-- Bootstrap 4.1.1 JS CDN -->
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" ></script>
    <!-- Bootstrap 4.1.1 JS local fallback -->
    <script>if(typeof($.fn.modal) === 'undefined') {document.write('<script src="bootstrap/js/bootstrap.min.js"><\/script>')}</script>
    <!-- Bootstrap 4.1.1 CSS local fallback -->
    <div id="bootstrapCssTest" class="hidden"></div>
    <script>
      $(function() {
        if ($('#bootstrapCssTest').is(":visible")) {
          $("head").prepend('<link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">');
        }
      });
    </script>
  </body>
</html>

最佳答案

在进一步试验之后,我发现我需要做的就是将 class="hidden" 替换为 class="collapse"

这里是更正后的代码,以防有人想查看/使用它:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <!-- Bootstrap 4.1.1 CSS CDN -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css">
    <title>Home | phpMIDAS viewer</title>
  </head>
  <body>
    <!-- jQuery 3.3.1 CDN -->
    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"></script>
    <!-- Bootstrap 4.1.1 JS CDN -->
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js" ></script>
    <!-- Bootstrap 4.1.1 JS local fallback -->
    <script>if(typeof($.fn.modal) === 'undefined') {document.write('<script src="bootstrap/js/bootstrap.min.js"><\/script>')}</script>
    <!-- Bootstrap 4.1.1 CSS local fallback -->
    <div id="bootstrapCssTest" class="collapse"></div>
    <script>
      $(function() {
        if ($('#bootstrapCssTest').is(":visible")) {
          $("head").prepend('<link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">');
        }
      });
    </script>
  </body>
</html>

关于css - 回退到本地 bootstrap 4 css 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50884212/

相关文章:

css - 如何在 Angular 6+ 中使 mat-form-field-underline 的高度为 0

javascript - 如何在 CSS 中使用 Javascript 变量?

javascript - 重置 HTML 正文后 Bootstrap 模式不会关闭

javascript - 有没有办法防止在html中重复代码我正在使用bootstrap 4在一页中折叠20次

背景大小的 jQuery 回退

javascript - 将文本添加到 D3 donut chart 的中心

css - 如何在此免费主题上自定义横幅宽度?

jquery - Bootstrap 4 中的下拉菜单内折叠

css - CSS 中的 IE 7 回退

JavaScript 变量回退