Неожиданная синтаксическая ошибка при развертывании приложения Vue на Heroku

У меня было приложение Vue, настроенное с шаблоном веб-пакета Vue CLI, и я пытался развернуть его на Heroku с помощью Node.js.

  1. Сначала я запускаю npm run build (сборка с файлом webpack.prod), чтобы все файлы находились в dist/.
  2. Затем я запускаю git push heroku master, чтобы развернуть его.

Когда я открываю Интернет, возникает ошибка. Я заметил, что все файлы .js были изменены и теперь содержат то же содержимое, что и мой index.html:

Неожиданная синтаксическая ошибка при развертывании приложения Vue на HerokuНеожиданная синтаксическая ошибка при развертывании приложения Vue на Heroku

Вот мой файл server.js:

var express = require('express');
var path = require('path');
var history = require('connect-history-api-fallback');

var app = express();

var staticFileMiddleware = express.static(path.join(__dirname + '/dist'));

app.set('port',process.env.PORT||5000);

app.use(history({
  disableDotRule: true,
  verbose: true
}));
app.use(staticFileMiddleware);

app.listen(app.get('port'), function () {
    console.info("App now running on port", app.get('port'));
});


app.get('/', function (req, res) {
  res.render(path.join(__dirname + '/dist/index.html'));
});

Почему это происходит и как это исправить?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
73
1

Ответы 1

First I run npm run build… Then I run git push heroku master to deploy it"

Если вы нам что-то не говорите, npm run build здесь не делает ничего полезного. git push работает с коммитами, но ваши сгенерированные файлы dist/ не были зафиксированы.

Хотя, наверное, это нормально, поскольку Heroku может сам построить ваше приложение. Добавьте сценарий postinstall в файл package.json, чтобы рассказать, как:

"scripts": {
  "postinstall": "npm run build"
}

Это предполагает, что ваша сборка действительно генерирует корректный вывод в dist/. Если этого не происходит, придется разобраться со второй проблемой.

Другие вопросы по теме