gpt4 book ai didi

javascript - 无法使用 Webpacker 在 Ruby on Rails 6 中调用 Bootstrap4 $ ('.carousel'.carousel

转载 作者:行者123 更新时间:2023-12-04 15:35:12 24 4
gpt4 key购买 nike

我正在使用 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"
}
}

最佳答案

我的 environment.js 中有以下内容:

const { environment } = require('@rails/webpacker')

const webpack = require('webpack')
environment.plugins.prepend('Provide',
new webpack.ProvidePlugin({
$: 'jquery',
jQuery: 'jquery',
Popper: ['popper.js', 'default']
})
)

module.exports = environment

这使得 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。让这样的东西起作用,然后重新添加您的卡片和样式。

关于javascript - 无法使用 Webpacker 在 Ruby on Rails 6 中调用 Bootstrap4 $ ('.carousel'.carousel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60009513/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com