【问题标题】:Jquery not working after precompile预编译后 Jquery 不工作
【发布时间】:2013-10-09 11:49:16
【问题描述】:

图像导致我的 heroku 应用出现问题,因此我在 production.rb 中将 config.assets.compile = false 更改为 config.assets.compile = true。然后我运行rake assets:precompile 并推送到heroku 服务器。 Jquery 在应用程序网站上运行良好,但不再适用于我的本地副本。 javascript 控制台中不会引发任何错误。以下是一些重要的文件。

生产.rb

Nonogrammed::Application.configure do
  # Settings specified here will take precedence over those in config/application.rb

  # Code is not reloaded between requests
  config.cache_classes = true

  # Full error reports are disabled and caching is turned on
  config.consider_all_requests_local       = false
  config.action_controller.perform_caching = true

  # Disable Rails's static asset server (Apache or nginx will already do this)
  config.serve_static_assets = false

  # Compress JavaScripts and CSS
  config.assets.compress = true

  # Don't fallback to assets pipeline if a precompiled asset is missed
  config.assets.compile = false

  # Generate digests for assets URLs
  config.assets.digest = true

  # Defaults to nil and saved in location specified by config.assets.prefix
  # config.assets.manifest = YOUR_PATH

  # Specifies the header that your server uses for sending files
  # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
  # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx

  # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
  # config.force_ssl = true

  # See everything in the log (default is :info)
  # config.log_level = :debug

  # Prepend all log lines with the following tags
  # config.log_tags = [ :subdomain, :uuid ]

  # Use a different logger for distributed setups
  # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)

  # Use a different cache store in production
  # config.cache_store = :mem_cache_store

  # Enable serving of images, stylesheets, and JavaScripts from an asset server
  # config.action_controller.asset_host = "http://assets.example.com"

  # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added)
  # config.assets.precompile += %w( search.js )

  # Disable delivery errors, bad email addresses will be ignored
  # config.action_mailer.raise_delivery_errors = false

  # Enable threaded mode
  # config.threadsafe!

  # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
  # the I18n.default_locale when a translation can not be found)
  config.i18n.fallbacks = true

  # Send deprecation notices to registered listeners
  config.active_support.deprecation = :notify

  # Log the query plan for queries taking more than this (works
  # with SQLite, MySQL, and PostgreSQL)
  # config.active_record.auto_explain_threshold_in_seconds = 0.5
end

应用程序.js

//= require jquery
//= require jquery_ujs
//= require jquery.ui.core
//= require jquery.ui.widget
//= require jquery.ui.mouse
//= require jquery.ui.draggable
//= require twitter/bootstrap
//= require_tree .


$(function() {
    $( "#draggable" ).draggable({ handle: "#handle" , containment: [0,0,1200,1000] , cursor: "crosshair" });
  });

更新:这是由于删除图像,创建具有相同名称的新图像,然后推送到 heroku 造成的。不要那样做!

【问题讨论】:

    标签: javascript jquery ruby-on-rails ruby heroku


    【解决方案1】:

    无需在本地进行预编译。 Sprockets 在服务器启动时自动编译静态资源。

    要解决问题,请删除 public/assets 目录中的编译文件,提交更改,然后再次部署到 Heroku。

    然后,在 Heroku 中,通过从命令行运行以下命令来编译资产:

    # from command line via the Heroku Toolbelt
    rake run assets:precompile
    

    您的本地资产将在服务器启动时编译(从而使 jQuery 再次可用),并且您在 Heroku 上的资产将按原样预编译到 public/assets 目录。

    更新

    您可能需要清除浏览器缓存以确保将更新的资产路径加载到您的标记中。

    【讨论】:

    • app/assets 目录下没有看到编译好的文件,是不是被隐藏了?
    • 抱歉,应该是public/assets。我已经更新了我的答案以反映。
    • 删除编译后的文件,并重置服务器后,jquery 应该可以工作吗?因为不是。也许我没有删除所有编译的文件?
    • 应该...你验证过import标签是否在你的HTML<head>中正确导入了jQuery?
    • 如果这个答案有帮助,你会考虑接受它是正确的吗?此外,我已经更新了我的答案,以反映您关于清除浏览器缓存的评论。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-05-09
    • 1970-01-01
    相关资源
    最近更新 更多