3

GULP を使用してデモを作成しましたが、gulp js ファイルを実行する際に問題に直面しています。

インストールのプロセス:

sudo npm init 
sudo npm install gulp-jshint gulp-sass gulp-concat gulp-uglify gulp-rename --save-dev
sudo npm install --save-dev gulp

コンソール警告:

mnbcvd3456:glp user$ sudo npm install gulp
npm WARN package.json gulp@3.8.6 No repository field.
npm WARN install Refusing to install gulp as a dependency of itself

パッケージ.JSON:

{
  "name": "gulp",
  "version": "3.8.6",
  "description": "Gulp Demo",
  "main": "index.js",
  "directories": {
    "doc": "doc"
  },
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "User",
  "license": "ISC",
  "devDependencies": {
    "gulp-concat": "^2.3.3",
    "gulp-jshint": "^1.7.1",
    "gulp-rename": "^1.2.0",
    "gulp-sass": "^0.7.2",
    "gulp-uglify": "^0.3.1"
  }
}

Gulp.js ファイル。

// Include gulp
var gulp = require('gulp');

// Include Our Plugins
var jshint = require('gulp-jshint');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var rename = require('gulp-rename');

// Lint Task
gulp.task('lint', function() {
    return gulp.src('js/*.js')
        .pipe(jshint())
        .pipe(jshint.reporter('default'));
});

// Concatenate & Minify JS
gulp.task('scripts', function() {
    return gulp.src('js/*.js')
        .pipe(concat('all.js'))
        .pipe(gulp.dest('dist'))
        .pipe(rename('all.min.js'))
        .pipe(uglify())
        .pipe(gulp.dest('dist'));
});

// Watch Files For Changes
gulp.task('watch', function() {
    gulp.watch('js/*.js', ['lint', 'scripts']);
});

// Default Task
gulp.task('default', ['lint', 'scripts', 'watch']);

今、コマンド「gulp」を使用して、gulp js ファイルを実行しようとしている場合。次に、次のようなエラーが表示されます。

mnbcvd3456:glp user$ gulp

    module.js:340
        throw err;
              ^
    Error: Cannot find module 'gulp'
        at Function.Module._resolveFilename (module.js:338:15)
        at Function.Module._load (module.js:280:25)
        at Module.require (module.js:364:17)
        at require (module.js:380:17)
        at Object.<anonymous> (/Users/glp/gulpfile.js:5:12)
        at Module._compile (module.js:456:26)
        at Object.Module._extensions..js (module.js:474:10)
        at Module.load (module.js:356:32)
        at Function.Module._load (module.js:312:12)
        at Module.require (module.js:364:17)
4

2 に答える 2

2

問題は、「name」に 「gulp」という名前を付けたことです。

「name」「gulp」以外の任意の名前に変更します。

これも見ることができます: https://github.com/npm/npm/issues/13898

于 2016-09-16T07:59:31.723 に答える
0

問題は、両方のインストールが同じレベルにあることにあると思います。したがって、grunt と gulp の両方が pakage.json にアクセスしようとします。

それらを別のフォルダーにインストールしてみてください。

また、gulp をグローバルにインストールしてから、grunt とは別のフォルダーにローカルにインストールし、次のような空のパッケージを作成します。

{
  "name": "name_you_want",
  "version": "0.0.1",
  "devDependencies": { }
}

次のようにdev用のプラグインを追加します(package.jsonがあるフォルダーにコマンドライン:npm install --save-dev plugin_name

さらに、なぜ grunt と gulp の両方を使用するのですか?

于 2014-07-15T09:05:09.263 に答える