【问题标题】:Bootstrap 5 - offcanvas component not displayed in vue 3 appBootstrap 5 - vue 3 应用程序中未显示 offcanvas 组件
【发布时间】:2021-04-26 23:28:09
【问题描述】:

我正在尝试将 bootstrap 5 的新 offcanvas 组件集成到我的 vue 应用程序中。我有这段代码,在构建应用程序后,我想测试它,但我看不到 offcanvas 菜单。我没有加载 js 插件来维护我的应用程序灯,我正在使用将绑定所需类的变量添加显示类。我该如何解决?

<template>
  <nav class="navbar navbar-collapse bg-light fixed-top">
    <div class="container">
      <span class="float-start">
        <button class="navbar-toggler" type="button" @click.prevent="showOffcanvasMenu()">
          <span class="navbar-toggler-icon"></span>
        </button>
      </span>
    </div>
    <div class="offcanvas offcanvas-start" :class="showMenu ? '' : 'show'" tabindex="-1">
      <div class="offcanvas-header">
        <h5 class="offcanvas-title" id="">Offcanvas with backdrop</h5>
        <button type="button" class="btn-close text-reset" @click.prevent="showOffcanvasMenu()"></button>
      </div>
      <div class="offcanvas-body">
        <p>.....</p>
      </div>
    </div>
  </nav>
  
  <!-- <div class="container-fluid bg-light p-0" v-show="isLoading">
    <div class="row">
      <div class="col-12 text-center">
        <div class="spinner-grow text-primary" role="status">
          <span class="visually-hidden">Loading...</span>
        </div>    
      </div>
    </div>
  </div> -->

  <router-view/>
</template>

<script>

export default {
  name: 'App',
  data(){
    return {
      showMenu: false
    }
  },
  methods: {
    showOffcanvasMenu(){
      this.showMenu ? this.showMenu = false : this.showMenu = true;
    }
  }
}
</script>

<style lang="scss">
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  //color: #2c3e50;
}
</style>

【问题讨论】:

    标签: javascript vue.js bootstrap-5 off-canvas-menu


    【解决方案1】:

    我发现了一些问题。

    首先:class条件逻辑反了,应该是:

    :class="showMenu ? 'show' : ''" 
    

    其次(更大的问题)是简单地切换 show 类并不能控制 Offcanvas 元素的显示。 Offcanvas JS 组件不仅仅是切换show 类。它还更改了 visibility 属性并连接了其他几个方法/事件。

    解决方法

    1 - 一种选择是不使用 Vue 来切换 Offcanvas 元素,而只需使用 vanilla JS data-bs- 属性。

    或者,

    2 - 另一种选择是还根据 showMenu 的值切换元素的 visibility 属性...

    :style="{ visibility: showMenu ? 'visible' : 'hidden' }
    

    Demo

    或者,

    3 - 为 Bootstrap 的 Offcanvas 组件创建一个 Vue 包装器组件。

    【讨论】:

    • 感谢您的帮助。我注意到关于 offcanvas 的 visibility 并且我在我的 scss 规则集中添加了一个规则,以在我必须显示菜单的变量设置为 true 时修改可见性。
    猜你喜欢
    • 1970-01-01
    • 2017-06-28
    • 2021-09-26
    • 2020-05-07
    • 2014-10-05
    • 2022-10-14
    • 2023-03-16
    • 1970-01-01
    • 2020-09-03
    相关资源
    最近更新 更多