简体   繁体   English

如何编写一个简单的 gulp 管道函数?

[英]How can I write a simple gulp pipe function?

I've been trying for a day to write two pipe functions, one that compiles less files and another one that concats these files.我已经尝试了一天来编写两个管道函数,一个编译较少的文件,另一个连接这些文件。 I want to learn how to write transform streams/pipes for more complex plugins.我想学习如何为更复杂的插件编写转换流/管道。

So I want to know how to read data from another pipe, and how to alter that data and send it to the next pipe.所以我想知道如何从另一个管道读取数据,以及如何更改该数据并将其发送到下一个管道。 This is what I have so far:这是我到目前为止:

 gulp.src(sources)
   .pipe(through.obj(function (chunk, enc, cb) {

     var t = this;
     // console.log("chunk", chunk.path);
     fs.readFile(chunk.path, enc, function (err,data) {
       if (err) { cb(err); }

       less.render(data, {
         filename : chunk.path,
         sourceMap : {
           sourceMapRootpath : true
         }
       })
       .then(function (outputCss) {
          // console.log("less result",outputCss);
          t.push(chunk);// or this.push(outputCss) same result
          cb();
       });

     });

   }))
   .pipe(through.obj(function (chunk, enc, cb) {
     console.log("chunk", chunk.path); // not event getting called.
     cb();
   }))

I can't get the outputCSS for each file in the second pipe.我无法获得第二个管道中每个文件的outputCSS How can I send it?我该如何发送?

Well, you don't need to use fs here, you already got the stream of file (here your chunk ).好吧,您不需要在这里使用fs ,您已经获得了文件流(这里是您的chunk )。

Another point, you're not sending back to the pipe the files, so I guess that's why nothing is called on your second one.另一点,您没有将文件发送回管道,所以我想这就是为什么您的第二个文件没有被调用的原因。

const through = require('through2')

gulp.src(sources)
  .pipe(through.obj((chunk, enc, cb) => {
    console.log('chunk', chunk.path) // this should log now
    cb(null, chunk)
  }))

In ES2015:在 ES2015 中:

import through from 'through2'

gulp.src(sources)
  .pipe(through.obj((chunk, enc, cb) => cb(null, chunk)))

And for your specific example:对于您的具体示例:

.pipe(through.obj((file, enc, cb) => {
  less.render(file.contents, { filename: file.path, ... }) // add other options
    .then((res) => {
      file.contents = new Buffer(res.css)
      cb(null, file)
    })
}))

This is still pretty basic, I don't check for errors, if it's not a stream and so on, but this should give you some hint on what you've missed.这仍然是非常基本的,我不检查错误,如果它不是流等等,但这应该会给你一些关于你错过了什么的提示。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM