无法使用Webpacker在Ruby on Rails 6中调用Bootstrap4 $('。carousel')。carousel。

问题描述 投票:1回答:1
我正在使用Ruby on Rails 6和webpacker。尝试添加轮播幻灯片,看起来像this(Bootstrap 4 Card Slider)但是,当我单击按钮以显示下一张(或上一张)幻灯片时,在控制台中会弹出Uncaught TypeError: $(...).carousel is not a function。即使我直接在控制台中编写脚本$('.carousel').carousel,也会发生相同的错误。我看到多次加载JQuery会导致类似的错误,但是我不知道自己这样做了。以下是我的代码。任何建议都是有帮助的。

app / views / home_page / test.html.erb

<%= javascript_pack_tag "carousel" %> <section class="container p-t-3"> <div class="row"> <div class="col-lg-12"> <h1>Bootstrap 4 Card Slider</h1> </div> </div> </section> <section class="carousel slide" data-ride="carousel" id="postsCarousel"> <div class="container"> <div class="row"> <div class="col-xs-12 text-md-right lead"> <a class="btn btn-outline-secondary prev" href="" title="go back"><i class="fa fa-lg fa-chevron-left"></i></a> <a class="btn btn-outline-secondary next" href="" title="more"><i class="fa fa-lg fa-chevron-right"></i></a> </div> </div> </div> <div class="container p-t-0 m-t-2 carousel-inner"> <div class="row row-equal carousel-item active m-t-0"> <div class="col-md-3"> <div class="card"> <div class="card-img-top card-img-top-250"> <img class="img-fluid" src="http://i.imgur.com/EW5FgJM.png" alt="Carousel 1"> </div> </div> </div> <div class="col-md-3"> <div class="card"> <div class="card-img-top card-img-top-250"> <img class="img-fluid" src="http://i.imgur.com/Hw7sWGU.png" alt="Carousel 2"> </div> </div> </div> <div class="col-md-3"> <div class="card"> <div class="card-img-top card-img-top-250"> <img class="img-fluid" src="http://i.imgur.com/g27lAMl.png" alt="Carousel 3"> </div> </div> </div> </div> <div class="row row-equal carousel-item m-t-0"> <div class="col-md-3"> <div class="card"> <div class="card-img-top card-img-top-250"> <img class="img-fluid" src="//visualhunt.com/photos/l/1/office-student-work-study.jpg" alt="Carousel 4"> </div> </div> </div> <div class="col-md-3"> <div class="card"> <div class="card-img-top card-img-top-250"> <img class="img-fluid" src="//visualhunt.com/photos/l/1/working-woman-technology-computer.jpg" alt="Carousel 5"> </div> </div> </div> <div class="col-md-3 fadeIn wow"> <div class="card"> <div class="card-img-top card-img-top-250"> <img class="img-fluid" src="//visualhunt.com/photos/l/1/people-office-team-collaboration.jpg" alt="Carousel 6"> </div> </div> </div> </div> </div> </section>

app / javascript / packs / carousel.js

(function($) { "use strict"; // manual carousel controls $('.next').click(function(){ $('.carousel').carousel('next');return false; }); $('.prev').click(function(){ $('.carousel').carousel('prev');return false; }); })(jQuery);

config / webpack / environment.js

const { environment } = require('@rails/webpacker') const webpack = require('webpack') environment.plugins.prepend( 'Provide', new webpack.ProvidePlugin({ $: 'jquery/src/jquery', jQuery: 'jquery/src/jquery', jquery: 'jquery/src/jquery', Popper: 'popper.js' }) ) module.exports = environment

app / javascript / packs / application.js

require("@rails/ujs").start() require("turbolinks").start() require("@rails/activestorage").start() require("channels") require("trix") require("@rails/actiontext") import '../src/application' import 'bootstrap'

app / javascript / src / application.scss

@import '~bootstrap/scss/bootstrap';

package.json

{ "name": "sample", "private": true, "dependencies": { "@rails/actioncable": "^6.0.0", "@rails/actiontext": "^6.0.2-1", "@rails/activestorage": "^6.0.0", "@rails/ujs": "^6.0.0", "@rails/webpacker": "4.2.2", "bootstrap": "4.3.1", "jquery": "^3.4.1", "popper.js": "^1.16.1", "trix": "^1.0.0", "turbolinks": "^5.2.0" }, "version": "0.1.0", "devDependencies": { "webpack-dev-server": "^3.10.1" } }
我正在使用Ruby on Rails 6和webpacker。试图添加轮播幻灯片看起来像这样(Bootstrap 4 Card Slider)但是,当我单击按钮以显示下一张(或上一张)幻灯片时,Uncaught TypeError:...
javascript ruby-on-rails webpack bootstrap-4 ruby-on-rails-6
1个回答
0
投票
这使jquery可与webpacker一起使用。

然后在您的application.scss中

@import '~bootstrap';

接下来,您的test.html.rb有点混乱。这是一个简化版本,无需卡片和其他样式即可使用:

<section class="container"> <h1>Bootstrap 4 Card Slider</h1> </section> <section class="container"> <a class="btn btn-lg" href="#carouselExample" role="button" data-slide="prev"> <span> &laquo; </span> </a> <a class="btn btn-lg" href="#carouselExample" role="button" data-slide="next"> <span> &raquo; </span> </a> <div id="carouselExample" class="carousel slide" data-ride="carousel"> <div class="carousel-inner"> <div class="carousel-item active"> <img class="d-block w-100" src="http://i.imgur.com/EW5FgJM.png" alt="First slide"> </div> <div class="carousel-item"> <img class="d-block w-100" src="http://i.imgur.com/Hw7sWGU.png" alt="Second slide"> </div> <div class="carousel-item"> <img class="d-block w-100" src="http://i.imgur.com/g27lAMl.png" alt="Third slide"> </div> </div> </div> </section>

这使用数据属性,因此您不需要carousel.js中的任何javascript。使类似的东西起作用,然后重新添加卡片和样式。
© www.soinside.com 2019 - 2024. All rights reserved.