Могу ли я безопасно включить bootstrap.js в проект bootstrap-vue?

Я разрабатываю небольшое приложение VueJS, похожее на калькулятор, которое будет подключено к элементу DOM на существующей «статической» странице на CMS, посвященной Bootstrap 4. Панель навигации и другие функции сайта основаны на ванильном Bootstrap 4 CSS / JS. Не будет никакого взаимодействия с DOM между частями страницы, не относящимися к Vue и Vue. Части, не относящиеся к Vue, - это простой контент и навигация.

В настоящее время без использования Bootstrap-Vue все работает нормально.

Я хотел бы использовать компоненты Bootstrap-Vue в частях страницы, управляемых VueJS. Согласно документации этих компонентов:

Если вы уже использовали Bootstrap 4, вам, возможно, придется внести в свой проект несколько изменений: [1] Удалите файл bootstrap.js из сценариев страницы или конвейера сборки, [2] ...

Поскольку части страницы, не относящиеся к Vue, используют bootstrap.js, могу ли я просто включить как библиотеки bootstrap.js, так и библиотеки bootstrap-vue.js во время выполнения? Есть вопросы, о которых мне следует знать?


person Eric K    schedule 25.10.2018    source источник


Ответы (1)


В следующем примере я использовал две части: одна указана для Vue, а другая - только для начальной загрузки.

Я привожу следующий упрощенный пример, чтобы показать вам, как это сделать.

new Vue({
  el: '#app',

  data() {
    return {
    item:'',
     currentPassword:'',
     req:false
    }
  },
  methods: {
  changePassword: function() {
    this.req=true;
    }
  }

});
<link type="text/css" rel="stylesheet" href="//unpkg.com/bootstrap/dist/css/bootstrap.min.css" />
<link type="text/css" rel="stylesheet" href="//unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.css" />

<!-- Add this after vue.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.16/vue.js"></script>
<script src="//unpkg.com/babel-polyfill@latest/dist/polyfill.min.js"></script>
<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>
<script src="//unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.js"></script>

<body>
<div id="outOfVue">
<p>
  <a class="btn btn-primary" data-toggle="collapse" href="#collapseExample" role="button" aria-expanded="false" aria-controls="collapseExample">
    Link with href
  </a>
  <button class="btn btn-primary" type="button" data-toggle="collapse" data-target="#collapseExample" aria-expanded="false" aria-controls="collapseExample">
    Button with data-target
  </button>
</p>
<div class="collapse" id="collapseExample">
  <div class="card card-body">
    Anim pariatur cliche reprehenderit, enim eiusmod high life accusamus terry richardson ad squid. Nihil anim keffiyeh helvetica, craft beer labore wes anderson cred nesciunt sapiente ea proident.
  </div>
</div>
</div>
<div id="app" class="container">
  <div>
    
    <b-form validated="" id="passwordChangeForm" @submit.prevent="changePassword" class="container-fluid">
      <b-form-group id="currentPassword" label="Old password">
        <b-form-input id="password" v-model="currentPassword" placeholder="Enter your old Password" type="password" :required="req" />
      </b-form-group>
      <b-button type="submit" variant="primary">Submit</b-button>
    </b-form>
  </div>
</div>
</body>

person Boussadjra Brahim    schedule 28.10.2018
comment
Пример очень полезен. Это именно то, что мне нужно. Теперь я могу собрать страницы вместе, используя бэкэнд CMS, и они смогут работать вместе. - person Eric K; 28.10.2018