[英]Vue.js not working on Heroku Rails app
我一直在嘗試將Rails + Vue.js應用程序部署到Heroku。 Vue.js可以在本地正常運行,但不能在Heroku上運行。 我覺得我沒有對資產管道做任何事情,但無法弄清楚是什么。
我正在為Vue使用vuejs-rails
gem,這是完整的Gemfile:
source 'https://rubygems.org'
ruby '2.3.1'
git_source(:github) do |repo_name|
repo_name = "#{repo_name}/#{repo_name}" unless repo_name.include?("/")
"https://github.com/#{repo_name}.git"
end
# Assets
gem 'vuejs-rails'
gem 'bootstrap', '~> 4.0.0.alpha6'
gem 'rails', '~> 5.0.1'
gem 'jquery-rails'
gem 'jbuilder', '~> 2.5'
gem 'coffee-rails', '~> 4.2'
gem 'sass-rails', '~> 5.0'
gem "haml-rails", "~> 0.9"
gem 'dentaku'
gem "browserify-rails"
# Server
gem 'puma', '~> 3.0'
gem 'pg'
gem 'uglifier', '>= 1.3.0'
gem 'rollbar'
# Use Capistrano for deployment
# gem 'capistrano-rails', group: :development
group :development, :test do
# Call 'byebug' anywhere in the code to stop execution and get a debugger console
gem 'byebug', platform: :mri
end
group :development do
# Access an IRB console on exception pages or by using <%= console %> anywhere in the code.
gem 'web-console', '>= 3.3.0'
gem 'listen', '~> 3.0.5'
# Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
gem 'spring'
gem 'spring-watcher-listen', '~> 2.0.0'
end
group :test do
gem 'rspec-rails'
end
# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]
//= require jquery
//= require jquery_ujs
//= require bootstrap-sprockets
//= require vue
//= require_tree .
如我的App.json中所示,我已經配置了多個Heroku Buildpacks
{
"name": "test_name",
"description": "Some stuff",
"addons": [
"deployhooks",
"newrelic",
"rollbar"
],
"buildpacks": [
{
"url": "heroku/nodejs"
},
{
"url": "urn:buildpack:heroku/ruby"
}
]
}
這是我部署到Heroku時的輸出。 看起來不像資產:precompile做任何事情:
remote: Compressing source files... done.
remote: Building source:
remote:
remote: -----> Node.js app detected
remote:
remote: -----> Creating runtime environment
remote:
remote: NPM_CONFIG_LOGLEVEL=error
remote: NPM_CONFIG_PRODUCTION=true
remote: NODE_VERBOSE=false
remote: NODE_ENV=production
remote: NODE_MODULES_CACHE=true
remote:
remote: -----> Installing binaries
remote: engines.node (package.json): unspecified
remote: engines.npm (package.json): unspecified (use default)
remote:
remote: Resolving node version 6.x via semver.io...
remote: Downloading and installing node 6.10.2...
remote: Using default npm version: 3.10.10
remote:
remote: -----> Restoring cache
remote: Loading 2 from cacheDirectories (default):
remote: - node_modules
remote: - bower_components (not cached - skipping)
remote:
remote: -----> Building dependencies
remote: Installing node modules (package.json)
remote:
remote: -----> Caching build
remote: Clearing previous node cache
remote: Saving 2 cacheDirectories (default):
remote: - node_modules
remote: - bower_components (nothing to cache)
remote:
remote: -----> Build succeeded!
remote: -----> Ruby app detected
remote: -----> Compiling Ruby/Rails
remote: -----> Using Ruby version: ruby-2.3.1
remote: -----> Installing dependencies using bundler 1.13.7
remote: Running: bundle install --without development:test --path vendor/bundle --binstubs vendor/bundle/bin -j4 --deployment
remote: Warning: the running version of Bundler (1.13.7) is older than the version that created the lockfile (1.14.6). We suggest you upgrade to the latest version of Bundler by running `gem install bundler`.
remote: Fetching gem metadata from https://rubygems.org/.........
remote: Fetching version metadata from https://rubygems.org/..
remote: Fetching dependency metadata from https://rubygems.org/.
remote: Using rake 12.0.0
remote: Using concurrent-ruby 1.0.5
remote: Using i18n 0.8.1
remote: Using minitest 5.10.1
remote: Using thread_safe 0.3.6
remote: Using builder 3.2.3
remote: Using erubis 2.7.0
remote: Using mini_portile2 2.1.0
remote: Using rack 2.0.1
remote: Using nio4r 2.0.0
remote: Using websocket-extensions 0.1.2
remote: Using mime-types-data 3.2016.0521
remote: Using arel 7.1.4
remote: Using public_suffix 2.0.5
remote: Using execjs 2.7.0
remote: Using sass 3.4.23
remote: Using method_source 0.8.2
remote: Using thor 0.19.4
remote: Using coffee-script-source 1.12.2
remote: Using dentaku 2.0.10
remote: Using tilt 2.0.7
remote: Using sexp_processor 4.9.0
remote: Using multi_json 1.12.1
remote: Using pg 0.20.0
remote: Using puma 3.8.2
remote: Using bundler 1.13.7
remote: Using vuejs-rails 2.2.1
remote: Using nokogiri 1.7.1
remote: Using websocket-driver 0.6.5
remote: Using mime-types 3.1
remote: Using addressable 2.5.1
remote: Using autoprefixer-rails 6.7.7.2
remote: Using uglifier 3.2.0
remote: Using rack-test 0.6.3
remote: Using sprockets 3.7.1
remote: Using tzinfo 1.2.3
remote: Using coffee-script 2.4.1
remote: Using ruby_parser 3.9.0
remote: Using haml 4.0.7
remote: Using rollbar 2.12.0
remote: Using loofah 2.0.3
remote: Using mail 2.6.4
remote: Using bootstrap 4.0.0.alpha6
remote: Using activesupport 5.0.2
remote: Using rails-html-sanitizer 1.0.3
remote: Using rails-dom-testing 2.0.2
remote: Using globalid 0.4.0
remote: Using activemodel 5.0.2
remote: Using jbuilder 2.6.3
remote: Using html2haml 2.1.0
remote: Using actionview 5.0.2
remote: Using activejob 5.0.2
remote: Using activerecord 5.0.2
remote: Using actionpack 5.0.2
remote: Using actioncable 5.0.2
remote: Using actionmailer 5.0.2
remote: Using railties 5.0.2
remote: Using sprockets-rails 3.2.0
remote: Using browserify-rails 4.1.0
remote: Using coffee-rails 4.2.1
remote: Using haml-rails 0.9.0
remote: Using jquery-rails 4.3.1
remote: Using rails 5.0.2
remote: Using sass-rails 5.0.6
remote: Bundle complete! 21 Gemfile dependencies, 64 gems now installed.
remote: Gems in the groups development and test were not installed.
remote: Bundled gems are installed into ./vendor/bundle.
remote: Bundle completed (2.30s)
remote: Cleaning up the bundler cache.
remote: Warning: the running version of Bundler (1.13.7) is older than the version that created the lockfile (1.14.6). We suggest you upgrade to the latest version of Bundler by running `gem install bundler`.
remote: -----> Detecting rake tasks
remote: -----> Preparing app for Rails asset pipeline
remote: Running: rake assets:precompile
remote: Asset precompilation completed (1.56s)
remote: Cleaning assets
remote: Running: rake assets:clean
remote:
remote: -----> Discovering process types
remote: Procfile declares types -> web
remote: Default types for buildpack -> console, rake, worker
remote:
remote: -----> Compressing...
remote: Done: 44.4M
remote: -----> Launching...
remote: Released v11
remote: https://nlp-calculator.herokuapp.com/ deployed to Heroku
remote:
remote: Verifying deploy... done.
有一個Javascript錯誤,具體地說,我需要包括Tether才能使用Bootstrap。 在本地沒有縮小,因此即使出現錯誤,Vue.js也可以正常工作。 但是在生產中,一個JS錯誤將完全停止整個應用程序JS的編譯。
確保我擁有該依賴關系可以解決問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.