javascript - 选择的 Jquery 在 Rails 4 应用程序上无法正常工作

标签 javascript jquery css ruby-on-rails twitter-bootstrap

我正在使用 Mailboxer 和 Chosen gem。用户可以从下拉菜单中选择多个用户。问题是,在初始加载时,下拉菜单似乎已经打开并且只允许您选择一个其他用户。如果我重新加载页面,下拉菜单会按预期显示。

当我在 chrome 检查器中检查它时,我得到 TypeError: undefined is not a function错误。我已经检查过 S.O 和谷歌,很多建议是更改我的 application.js 文件的顺序。我试过这个但无法在初始启动时正确触发。查看我的终端窗口,每个请求似乎都成功通过。

Dropdown on initial load, broken

Dropdown w/ refresh working properly

所以它确实有效,但为什么我必须刷新页面才能使其正常工作?

应用程序.js:

    ...
//
//= require jquery
//= require jquery.turbolinks
//= require jquery_ujs
//= require chosen-jquery
//= require bootstrap
//= require jquery.image-select
//= require messages
//= require turbolinks

应用程序.css.scss:

... 
 *
 *= require_tree .
 *= require_self
 */

@import 'bootstrap';
@import 'bootstrap/theme';
@import 'chosen';
...

消息.咖啡:

# Place all the behaviors and hooks related to the matching controller here.
# All this logic will automatically be available in application.js.
# You can use CoffeeScript in this file: http://coffeescript.org/
jQuery ->
  $('.chosen-it').chosen()

gem 文件:

source 'https://rubygems.org'
ruby '2.1.5'


gem 'rails', '4.2.0'

gem 'devise'
gem 'thin'
gem "simple_calendar"

gem 'bootstrap-sass'
gem 'bootstrap-will_paginate'

gem "mailboxer"

gem 'will_paginate' 

gem 'gravatar_image_tag'

group :development do
  gem 'sqlite3'
  gem 'better_errors'
  gem 'binding_of_caller'
  gem 'annotate'
end

group :production do
  gem 'pg'
  gem 'rails_12factor'
end

gem 'chosen-rails'
gem 'sass-rails', '~> 4.0.5'
# Use Uglifier as compressor for JavaScript assets
gem 'uglifier', '>= 1.3.0'
# Use CoffeeScript for .js.coffee assets and views
gem 'coffee-rails', '~> 4.1.0'
# See https://github.com/sstephenson/execjs#readme for more supported runtimes
# gem 'therubyracer',  platforms: :ruby

# Use jquery as the JavaScript library
gem 'jquery-rails'
# Turbolinks makes following links in your web application faster. Read more: https://github.com/rails/turbolinks
gem 'turbolinks'
gem 'jquery-turbolinks'
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
gem 'jbuilder', '~> 2.0'
# bundle exec rake doc:rails generates the API under doc/api.
gem 'sdoc', '~> 0.4.0',          group: :doc


#gem 'sass-rails', '4.0.4'

# Use ActiveModel has_secure_password
# gem 'bcrypt', '~> 3.1.7'

# Use unicorn as the app server
# gem 'unicorn'

# Use Capistrano for deployment
# gem 'capistrano-rails', group: :development

# Use debugger
# gem 'debugger', group: [:development, :test]

# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
gem 'tzinfo-data', platforms: [:mingw, :mswin]

有问题的文件,home.html.erb:

<div class="box">
    <div class="col-lg-12 text-center">
        <div id="carousel-example-generic" class="carousel slide">
            <!-- Indicators -->
            <ol class="carousel-indicators hidden-xs">
                <li data-target="#carousel-example-generic" data-slide-to="0" class="active"></li>
                <li data-target="#carousel-example-generic" data-slide-to="1"></li>
                <li data-target="#carousel-example-generic" data-slide-to="2"></li>
            </ol>
            <!-- Wrapper for slides -->
            <div class="carousel-inner">
                <div class="item active">
                    <%= image_tag "slide-1.jpg", :class => "img-responsive img-full" %>
                </div>
                <div class="item">
                    <%= image_tag "slide-2.jpg", :class => "img-responsive img-full" %>
                </div>
                <div class="item">
                    <%= image_tag "slide-5.jpg", :class => "img-responsive img-full" %>
                </div>
        <!-- Controls -->
        <a class="left carousel-control" href="#carousel-example-generic" data-slide="prev">
            <span class="icon-prev"></span>
        </a>
        <a class="right carousel-control" href="#carousel-example-generic" data-slide="next">
            <span class="icon-next"></span>
        </a>
</div>
            <h2 class="brand-before">
                <small>Welcome to</small>
            </h2>
            <h1 class="brand-name">Balern Education</h1>
            <hr class="tagline-divider">

        </div>
    </div>
</div>

    <div class="box">
        <hr>

        <hr>
            <%= image_tag "intro1.jpg", :class => "img-responsive img-border img-left" %>
            <hr class="visible-xs">

    </div>

    <div class="box">
        <hr>
        <h2 class="intro-text text-center">Balern really
            <strong>Cares</strong>
        </h2>
        <hr>

    </div>    <!-- /.container -->

<!-- jQuery -->
<script src="assets/jquery.js"></script>

<!-- Bootstrap Core JavaScript -->
<script src="assets/bootstrap.min.js"></script>

<!-- Script to Activate the Carousel -->
<script>
$('.carousel').carousel({
    interval: 5000 //changes the speed
})
</script>

最佳答案

尝试禁用 turbolinks。如果它开始正常工作,您要么想从元素中删除 turbolinks,要么安装 jquery-turbolinks gem

关于javascript - 选择的 Jquery 在 Rails 4 应用程序上无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28895039/

相关文章:

jquery - Bootstrap 选项卡在另一个页面上打开选项卡

javascript - 如何确保传入 Rails 服务器的请求是从 Rails View 发送的?

jquery - 添加内容时调整水平宽度

html - 在 CSS 中设计圆 Angular 矩形

javascript - 如何在 JQuery 中格式化 URL.Action() 调用以设置链接的 href 属性?

javascript - 通过 POST 将文件传递给 NodeJS,然后传递给另一个 API,而不保存在磁盘上

javascript - 在 css 动画完成后更改左值

javascript - 如何获得 js png 修复以处理 ajax 调用

javascript - 从 ngRoute 迁移到 ui.router

html - 固定页脚在页面底部