Grunt-작업 생성

이 장에서는 작업 생성에 대해 알아 보겠습니다 . Grunt를 실행할 때마다 수행 할 작업을 Grunt에 알리는 하나 이상의 작업이 실행되도록 지정됩니다. 기본 작업 을 지정하면 기본적으로 실행됩니다.

별칭 작업

작업 목록이 지정 될 때마다 하나 이상의 다른 작업에 새 작업의 별칭을 지정할 수 있습니다. 별칭을 실행하면 taskList에 지정된 모든 작업이 차례로 실행됩니다 . 태스크 목록 아래와 같이 인수 작업의 배열한다 -

grunt.registerTask(taskName, [description, ] taskList)

예를 들어, 사용자가 정의 할 때 작업 목록을 함께 jshint , CONCAT, 그리고 추하게 작업과 지정 TASKNAME를 같이 기본 경우, 나열된 모든 작업이 자동으로 실행됩니다 그런트가 어떤 작업을 지정하지 않고 실행됩니다.

grunt.registerTask('default', ['jshint', 'concat', 'uglify']);

다음과 같이 작업 인수를 지정할 수도 있습니다.

grunt.registerTask('dist', ['concat:dist', 'uglify:dist']);

위의 작업에서 별칭 distconcatuglify 작업을 모두 실행 합니다.

다중 작업

여러 작업을 실행할 때마다 Grunt는 Grunt 구성에서 동일한 이름의 속성을 검색합니다. 이러한 작업은 여러 구성을 가질 수 있으며 임의로 이름이 지정된 대상을 사용하여 정의됩니다 .

작업과 대상을 모두 지정하면 지정된 대상 구성 만 처리됩니다.

grunt concat:foo

위의 명령은 대상 foo 만 실행합니다 .

작업 만 지정하면 모든 대상이 처리됩니다.

grunt concat

위의 명령은 concat 작업 의 모든 대상을 반복 합니다.

grunt.task.renameTask를 사용 하여 작업의 이름을 바꾸면 Grunt가 구성 개체에서 작업 이름을 가진 속성을 검색합니다.

grunt.initConfig({
   log: {
      foo: [1, 2, 3],
      bar: 'Welcome to tutorialspoint',
      sap: true
   }
});

grunt.registerMultiTask('log', 'Log stuff.', function() {
   grunt.log.writeln(this.target + ': ' + this.data);
});

위의 예에서 멀티 태스크는 Grunt가 grunt log : foo를 통해 실행 된 경우 foo : 1,2,3을 기록 하거나 bar : Welcome to tutorialspointgrunt log : bar를 통해 실행할 때마다 로그합니다 . 그것은 기록합니다 1,2,3 : foo는 다음 바 : tutorialspoint에 오신 것을 환영합니다 다음 SAP : 사실 때 그런트 실행을로 꿀꿀 로그 .

기본 작업

기본 작업을 실행할 때마다 Grunt는 구성이나 환경을 검색하지 않습니다. 대신 지정된 태스크 함수를 실행하고 함수 인수로 지정된 콜론으로 구분 된 인수를 전달합니다.

grunt.registerTask(taskName, [description, ] taskFunction)

다음 예에서 태스크 는 grunt foo : testing : 123 명령을 통해 Grunt가 실행되는 경우 123을 테스트 하여 foo를 기록 합니다. 작업이 같은 인수없이 실행 될 때마다 툴툴 거리는 소리 foo는 작업이됩니다 foo는, 아니 인수를 기록 .

grunt.registerTask('foo', 'A simple task to logs stuff.', function(arg1, arg2) {
   if (arguments.length === 0) {
      grunt.log.writeln(this.name + ", no args");
   } else {
      grunt.log.writeln(this.name + ", " + arg1 + " " + arg2);
   }
});

사용자 지정 작업

다중 작업 구조 를 따르지 않으려면 아래와 같이 사용자 정의 작업을 정의 할 수 있습니다.

grunt.registerTask('default', 'My "default" task description.', function() {
  grunt.log.writeln('Currently running the "default" task.');
});

아래와 같이 다른 작업 내에서 작업을 실행할 수 있습니다.

grunt.registerTask('foo', 'My "foo" task.', function() {
   // Enqueue bar and baz tasks, to run after foo completes, in-order.
   grunt.task.run('bar', 'baz');
   // Or:
   grunt.task.run(['bar', 'baz']);
});

또한 아래와 같이 비동기 작업을 생성 할 수 있습니다.

grunt.registerTask('asyncfoo', 'My "asyncfoo" task.', function() {
   // Force task into async mode and grab a handle to the done() function.
   var done = this.async();
   // Run some sync stuff.
   grunt.log.writeln('Processing your task..');
   // Run some async stuff.
   setTimeout(function() {
      grunt.log.writeln('Finished!');
      done();
   }, 1000);
});

아래와 같이 이름과 인수에 액세스 할 수있는 작업을 만들 수 있습니다.

grunt.registerTask('foo', 'My task "foo" .', function(a, b) {
   grunt.log.writeln(this.name, a, b);
});

// Usage:
// grunt foo
//   logs: "foo", undefined, undefined
// grunt foo:bar
//   logs: "foo", "bar", undefined
// grunt foo:bar:baz
//   logs: "foo", "bar", "baz"

오류가 기록 될 때마다 아래와 같이 작업이 실패 할 수 있도록 작업을 생성 할 수 있습니다.

grunt.registerTask('foo', 'My task "foo" .', function() {
   if (failureOfSomeKind) {
      grunt.log.error('This is an error message.');
   }

   // If this task had errors then fail by returning false
   if (ifErrors) { return false; }

   grunt.log.writeln('This is success message');
});

작업이 실패 할 때마다 --force 를 지정 하지 않으면 모든 다음 작업이 종료 됩니다.

grunt.registerTask('foo', 'My task "foo" .', function() {
   // Fail synchronously.
   return false;
});

grunt.registerTask('bar', 'My task "bar" .', function() {
   var done = this.async();
   setTimeout(function() {
      // Fail asynchronously.
      done(false);
   }, 1000);
});

작업은 성공적인 실행을 위해 다른 작업에 종속 될 수 있습니다. 기억 grunt.task.requires이 대신은 실패한 실행하지 않았는지 확인합니다 실제로 다른 작업 (들)을 실행하지 않습니다.

grunt.registerTask('foo', 'My task "foo" .', function() {
   return false;
});

grunt.registerTask('bar', 'My task "bar" .', function() {
   // Fail task if foo task failed or never ran.
   grunt.task.requires('foo');
   // This code executes if the foo task executed successfully.
   grunt.log.writeln('Hello, World.. Welcome to Tutorialspoint!..');
});

// Usage:
// grunt foo bar doesn't log, because foo failed to execute.
// **Note: This is an example of space-separated sequential commands,
// (similar to executing two lines of code: `grunt foo` then `grunt bar`)
// grunt bar doesn't log, because foo never ran.

필요한 구성 속성을 찾을 수 없을 때마다 작업이 실패 할 수도 있습니다.

grunt.registerTask('foo', 'My task "foo" .', function() {
   // Fail task if meta.name config properties is missing
   // Format 1: String 
   grunt.config.requires('meta.name');
   // or Format 2: Array
   grunt.config.requires(['meta', 'name']);
   // Log... conditionally.
   grunt.log.writeln('This only log if meta.name is defined in the config.');
});

작업은 아래와 같이 구성 속성에 액세스 할 수 있습니다.

grunt.registerTask('foo', 'My task "foo" .', function() {
   // Log the value of the property. Returns null if the property is undefined.
   grunt.log.writeln('The meta.name property is: ' + grunt.config('meta.name'));
   // Also logs the value of the property. Returns null if the property is undefined.
   grunt.log.writeln('The meta.name property is: ' + grunt.config(['meta', 'name']));
});