簡體   English   中英

Vue.js無法在Heroku Rails應用程序上運行

[英]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]

的application.js

//= require jquery
//= require jquery_ujs
//= require bootstrap-sprockets
//= require vue
//= require_tree .

如我的App.json中所示,我已經配置了多個Heroku Buildpacks

App.json

{
  "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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM