Laravel Mix sh: 1: cross-env: not found error

Я пытался настроить Laravel Mix в своем проекте и следовал руководству по установке на веб-сайте Laravel, но продолжаю получать ошибки.

Мой package.json

{
  "private": true,
  "scripts": {
    "dev": "cross-env NODE_ENV=development webpack --progress --hide-modules",
    "watch": "cross-env NODE_ENV=development webpack --watch --progress --hide-modules",
    "hot": "cross-env NODE_ENV=development webpack-dev-server --inline --hot",
    "production": "cross-env NODE_ENV=production webpack --progress --hide-modules"
  },
  "devDependencies": {
    "axios": "^0.15.2",
    "bootstrap-sass": "^3.3.7",
    "jquery": "^3.1.0",
    "laravel-mix": "^0.4.0",
    "lodash": "^4.16.2",
    "vue": "^2.0.1"
  },
  "name": "Code",
  "version": "1.0.0",
  "main": "webpack.mix.js",
  "directories": {
    "test": "tests"
  },
  "dependencies": {
    "ansi-regex": "^2.1.1",
    "ansi-styles": "^2.2.1",
    "axios": "^0.15.3",
    "babel-core": "^6.24.1",
    "babel-code-frame": "^6.22.0",
    "babel-generator": "^6.24.1",
    "babel-messages": "^6.23.0",
    "babel-helpers": "^6.24.1",
    "babel-register": "^6.24.1",
    "babel-template": "^6.24.1",
    "babylon": "^6.17.0",
    "balanced-match": "^0.4.2",
    "babel-runtime": "^6.23.0",
    "babel-types": "^6.24.1",
    "babel-traverse": "^6.24.1",
    "brace-expansion": "^1.1.7",
    "bootstrap-sass": "^3.3.7",
    "chalk": "^1.1.3",
    "convert-source-map": "^1.5.0",
    "concat-map": "^0.0.1",
    "core-js": "^2.4.1",
    "cross-env": "^3.2.4",
    "detect-indent": "^4.0.0",
    "esutils": "^2.0.2",
    "escape-string-regexp": "^1.0.5",
    "follow-redirects": "^1.0.0",
    "globals": "^9.17.0",
    "has-ansi": "^2.0.0",
    "home-or-tmp": "^2.0.0",
    "is-finite": "^1.0.2",
    "invariant": "^2.2.2",
    "json5": "^0.5.1",
    "js-tokens": "^3.0.1",
    "jquery": "^3.2.1",
    "jsesc": "^1.3.0",
    "laravel-mix": "^0.4.0",
    "lodash": "^4.17.4",
    "loose-envify": "^1.3.1",
    "mkdirp": "^0.5.1",
    "minimatch": "^3.0.3",
    "minimist": "^0.0.8",
    "number-is-nan": "^1.0.1",
    "os-homedir": "^1.0.2",
    "os-tmpdir": "^1.0.2",
    "path-is-absolute": "^1.0.1",
    "private": "^0.1.7",
    "regenerator-runtime": "^0.10.3",
    "repeating": "^2.0.1",
    "slash": "^1.0.0",
    "source-map": "^0.5.6",
    "source-map-support": "^0.4.14",
    "strip-ansi": "^3.0.1",
    "trim-right": "^1.0.1",
    "to-fast-properties": "^1.0.2",
    "vue": "^2.3.0"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "description": ""
}

Ошибка, которую я получаю при выполнении любой команды npm run.

> [email protected] dev /home/vagrant/Code
> cross-env NODE_ENV=development webpack --progress --hide-modules

sh: 1: cross-env: not found

npm ERR! Linux 4.4.0-51-generic
npm ERR! argv "/usr/local/bin/node" "/usr/local/bin/npm" "run" "dev"
npm ERR! node v7.8.0
npm ERR! npm  v4.2.0
npm ERR! file sh
npm ERR! code ELIFECYCLE
npm ERR! errno ENOENT
npm ERR! syscall spawn
npm ERR! [email protected] dev: `cross-env NODE_ENV=development webpack --progress --hide-modules`
npm ERR! spawn ENOENT
npm ERR!
npm ERR! Failed at the [email protected] dev script 'cross-env NODE_ENV=development webpack --progress --hide-modules'.
npm ERR! Make sure you have the latest version of node.js and npm installed.
npm ERR! If you do, this is most likely a problem with the Code package,
npm ERR! not with npm itself.
npm ERR! Tell the author that this fails on your system:
npm ERR!     cross-env NODE_ENV=development webpack --progress --hide-modules
npm ERR! You can get information on how to open an issue for this project with:
npm ERR!     npm bugs Code
npm ERR! Or if that isn't available, you can get their info via:
npm ERR!     npm owner ls Code
npm ERR! There is likely additional logging output above.

npm ERR! Please include the following file with any support request:
npm ERR!     /home/vagrant/.npm/_logs/2017-04-28T17_24_11_458Z-debug.log

Я запускаю свой проект на ящике Vagrant и использую Laravel версии 5.4.


person GregorChristie    schedule 28.04.2017    source источник
comment
Я могу подтвердить, что следуя инструкциям по установке Laravel 5.4, вы получаете эти ошибки. См. Мой ответ для обходного пути.   -  person Yevgeniy Afanasyev    schedule 12.08.2017
comment
Использование Laravel 5.7 с Vagrant в окне bento / ubuntu-16.04. Поскольку я использую Linux, и это будет перенесено в производство, я просто обошел cross-env и изменил вызов cross-env с помощью set. Поскольку я не могу понять ошибку, которая, кажется, подкрадывается к бродяжничеству во многих моих чтениях, я полагаю, что мне не нужно это кроссплатформенное решение для установки переменных среды. Таким образом, мне поможет простая старая команда set. Надеется, что это поможет другим в подобных ситуациях. то есть: разработка: установите NODE_ENV = node_modules / webpack / bin / webpack.js ... в package.json   -  person mmv_sat    schedule 03.12.2018


Ответы (10)


Вам нужно заставить cross-env работать глобально, а не включать его в проект.

запустить

$ sudo npm install --global cross-env

--- Обновить ---

Но я советую избегать выполнения npm run ... в гостевой усадьбе, потому что это очень медленно и потому что от этого нет никакой пользы.

Независимо от того, где вы создаете активы, они будут выполняться в браузере. Так что вам лучше установить npm на свой хост-компьютер и построить там ресурсы.

person Yevgeniy Afanasyev    schedule 12.08.2017
comment
@leo для глобальных пакетов вам всегда понадобится sudo - person Darkshifty; 27.08.2019
comment
@Darkshifty Я сомневаюсь, я искал как в Google, так и в SO, и я не вижу, чтобы это упоминалось - person leo; 28.08.2019
comment
Это вообще не решает проблемы. Это просто обходной путь. Ожидается, что сценарии NPM будут видеть инструменты, установленные локально, без добавления их в глобальный PATH. - person fracz; 31.01.2020
comment
@fracz, ты прав. Если вы найдете способ исправить это, опубликуйте его здесь в качестве ответа. На самом деле я даже не пытаюсь запустить npm run на гостевой усадьбе, вместо этого я запускаю ее на моем хосте Windows. И он работает нормально, потому что кого волнует, где он был построен, если он будет выполняться на стороне клиента каким-либо образом. - person Yevgeniy Afanasyev; 04.02.2020

Сначала проверьте, установлен ли модуль cross-env. Если нет, запустите:

npm install cross-env

После этого нужно перейти в папку node_modules. Затем найдите папку cross-env. Войдите внутрь и найдите cross-env.js.

В моем случае это было node_modules/cross-env/dist/bin/cross-env.js

Вам нужно изменить путь к cross-env.js в разделе scripts вашего package.json файла.

{
  "private": true,
  "scripts": {
    "dev": "node_modules/cross-env/dist/bin/cross-env.js NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js",
    "watch": "node_modules/cross-env/dist/bin/cross-env.js NODE_ENV=development node_modules/webpack/bin/webpack.js --watch --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js",
    "hot": "node_modules/cross-env/dist/bin/cross-env.js NODE_ENV=development webpack-dev-server --inline --hot --config=node_modules/laravel-mix/setup/webpack.config.js",
    "production": "node_modules/cross-env/dist/bin/cross-env.js NODE_ENV=production node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js"
  },

........

}
person Andrew Bodnar    schedule 04.08.2017
comment
Это не помогло мне, но проголосовали за, потому что моя проблема была в перекрестном env, и этот ответ дал мне подсказку - person Yevgeniy Afanasyev; 11.08.2017
comment
У вас есть небольшая опечатка (название папки node_modules): в моем случае это было node_modules/cross-env/dist/bin/cross-env.js - person Pave; 15.09.2017
comment
Вам не нужно менять путь на cross-env, если вы устанавливаете его глобально (см. Ответ @YevgeniyAfanasyev). Он понадобится вам для всех ваших приложений Laravel, также может, и вам не нужно обновлять ваш package.json файл. - person Matt K; 29.01.2018

Запустить:

npm install

Затем попробуйте еще раз.

person PelleLV    schedule 20.06.2017
comment
При запуске виртуальной машины в среде на базе Windows это сработало для меня только после того, как я выключил Vagrant, закрыл Git Cmd, повторно открыл Git Cmd как администратор и запустил резервное копирование Vagrant и, наконец, запустил sudo npm install из каталога проекта. Если вы не выключите Vagrant до открытия Git Cmd с помощью Admin Priv, по моему опыту, вы столкнетесь с проблемами. - person Chad; 24.05.2019
comment
Это решило для меня ошибку cross-env. Ранее я заметил, что мой менеджер пакетов зависает при выполнении npm install. Поэтому я отменил процесс, удалил package-lock.json и снова запустил npm install. - person Benny64; 03.03.2021

Если приведенные выше решения не сработали, обновите node_modules, используя

rm -rf node_modules && npm install

это сработало для меня

person AMINEDGE    schedule 03.08.2019
comment
Это сработало для меня. Я не знаю, является ли это единственным важным шагом. Я сделал несколько из упомянутых шагов по порядку: - Я установил cross-env глобально - Я обновил путь до cross-env (теперь я думаю, что эти два шага, вероятно, взаимоисключающие) - Я остановил vagrant и перезапустил его во время работы cmd от имени администратора (проблема с символическими ссылками может быть связана, а может и нет). Затем я выполнил описанный выше шаг по обновлению node_modules. - person Hayden Bech; 17.04.2020

Есть несколько способов решить эту ошибку.

  • Удалите папку node_modules, затем повторите npm install. если не решит, то:

  • Вы можете установить как dev dependency, запустив

npm install --save-dev cross-env

если не решит, то:

  • Установить cross-env глобально как npm install --g cross-env. Он будет установлен в \ Users \ Roaming \ npm modules. Затем я предлагаю вам закрыть оболочку, открыть ее снова и запустить команду.

если это не решит, то: - в Package.json вы можете использовать как:

узел node_modules / dist / bin / cross-env cross-env ...

person Community    schedule 16.03.2018

Быстрое решение - запустить:

npm clean-install

это могло бы исправить ошибку микширования laravel.

person CutePotato    schedule 24.06.2020
comment
Сработал как шарм, спасибо @CutePotato - person Florian Doyen; 30.04.2021
comment
Удивительный! Я долго бился об этом, и это просто работает ~ - person user1015214; 28.07.2021

Иногда удаление /node_modules и запуск

npm install 

решит такие проблемы.

person kangular    schedule 11.10.2019

Вам нужно проверить, установлен ли модуль cross-env. Если нет, запустите:

npm install cross-env

Но вам нужно, чтобы это распознавалось как «команда». Исправление пути, предложенного принятым ответом (или это?), Привело меня к дальнейшему, но все же дало мне ошибку.

Решением для меня было перезагрузить vagrant «vagrant reload --provision» и сбросить сеанс ssh / putty.

person flap152    schedule 28.08.2017

Если вы просто отчаянно пытаетесь исправить эту ошибку, как мой случай, просто удалите cross-env из себя package.json и запустите laravel mix без него ..

person shamaseen    schedule 27.10.2019

Пришлось клонировать репозиторий в новую папку. Не удалось определить, какой локальный файл / параметр вызвал ошибку.

person Michael Freidgeim    schedule 21.10.2020