Для запуска nuxt необходимо наличие node_modules для запуска - PullRequest
0 голосов
/ 05 июня 2018

У меня есть nuxt-community/starter-template проект с минимальными дополнениями.Мой package.json выглядит следующим образом

{
  // ...
  "scripts": {
    "dev": "nuxt",
    "build": "nuxt build",
    "docker-image": "nuxt build && docker build -t unijobs-www-temp .",
    "start": "nuxt start",
    "generate": "NODE_ENV=production nuxt generate",
    "lint": "eslint --ext .js,.vue --ignore-path .gitignore .",
    "precommit": "npm run lint"
  },
  "dependencies": {
    "@fortawesome/fontawesome": "^1.1.8",
    "@fortawesome/fontawesome-free-brands": "^5.0.13",
    "@fortawesome/fontawesome-free-regular": "^5.0.13",
    "@fortawesome/fontawesome-free-solid": "^5.0.13",
    "@fortawesome/vue-fontawesome": "0.0.22",
    "nuxt": "^1.0.0",
    "nuxt-fontawesome": "^0.2.0",
    "node-sass": "^4.9.0",
    "sass-loader": "^7.0.2"
  },
  "devDependencies": {
    "babel-eslint": "^8.2.1",
    "eslint": "^4.15.0",
    "eslint-friendly-formatter": "^3.0.0",
    "eslint-loader": "^1.7.1",
    "eslint-plugin-vue": "^4.0.0"
  }
}

Локальное развитие выглядит хорошо, локальные build и start, кажется, работают нормально.Однако, когда я создаю образ Docker, все идет на юг. ПОЖАЛУЙСТА, ОБРАТИТЕ ВНИМАНИЕ это не проблема с Docker, то же самое верно, если я запускаю эквивалентные шаги на своем собственном компьютере в новом каталоге.

FROM node:stretch

ENV NODE_ENV=production
ENV HOST=0.0.0.0
EXPOSE 3000

RUN npm -g i nuxt
RUN mkdir -p /app
ADD .nuxt /app/.nuxt
ADD static /app/static
WORKDIR /app

CMD ["nuxt", "start"]

Это то, что я нахожу вжурналы:

2018-06-05T12:27:19.910Z nuxt:render Rendering url /
{ Error: Cannot find module 'core-js/library/fn/promise' from '/app'
    at Function.module.exports [as sync] (/usr/local/lib/node_modules/nuxt/node_modules/resolve/lib/sync.js:42:15)
    at r (/usr/local/lib/node_modules/nuxt/node_modules/vue-server-renderer/build.js:8332:44)
    at Object.<anonymous> (server-bundle.js:1429:18)
    at __webpack_require__ (server-bundle.js:27:30)
    at Object.module.exports.module.exports (server-bundle.js:105:31)
    at __webpack_require__ (server-bundle.js:27:30)
    at Object.<anonymous> (server-bundle.js:1218:138)
    at __webpack_require__ (server-bundle.js:27:30)
    at server-bundle.js:92:18
    at Object.<anonymous> (server-bundle.js:95:10)
    at evaluateModule (/usr/local/lib/node_modules/nuxt/node_modules/vue-server-renderer/build.js:8338:21)
    at /usr/local/lib/node_modules/nuxt/node_modules/vue-server-renderer/build.js:8396:18
    at new Promise (<anonymous>)
    at /usr/local/lib/node_modules/nuxt/node_modules/vue-server-renderer/build.js:8388:14
    at Object.renderToString (/usr/local/lib/node_modules/nuxt/node_modules/vue-server-renderer/build.js:8564:9)
    at Renderer.renderRoute (/usr/local/lib/node_modules/nuxt/lib/core/renderer.js:344:41)
  code: 'MODULE_NOT_FOUND',
  statusCode: 500,
  name: 'NuxtServerError' }

Однако все исчезает, как только я подключаю node_modules, рядом с каталогами .nuxt и static.Кажется, некоторые модули не входят в комплект.Мой nuxt.config.js файл похож на

module.exports = {
  head: {
    // Skipping noise...
  },
  modules: [
    [ 'nuxt-fontawesome', {
      component: 'fa',
      imports: [
        { set: '@fortawesome/fontawesome-free-brands' },
      ]
    }],
  ],
  loading: { color: '#3B8070' },
  build: {
    extend (config, { isDev, isClient }) {
      if (isDev && isClient) {
        config.module.rules.push({
          enforce: 'pre',
          test: /\.(js|vue)$/,
          loader: 'eslint-loader',
          exclude: /(node_modules)/
        })

// *** NOTE: In practice, I'm only using FA brands here, not the others ***

        config.resolve.alias['@fortawesome/fontawesome-free-brands$'] = '@fortawesome/fontawesome-free-brands/shakable.es.js'  
      }
    }
  }
}

Я что-то не так делаю?

1 Ответ

0 голосов
/ 09 июня 2019

Я обнаружил, что сборка Nuxt не будет связывать файлы в node_modules, поэтому, если вы хотите объединить все зависимости в .nuxt, вы должны использовать nuxt build --standalone.

см. Здесь: https://github.com/nuxt/nuxt.js/issues/4292

надеюсь, это поможет вам:)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...