将Markdown文件转换为PDF,同时剥离Jekyll Front-Matter

时间:2016-04-10 06:45:54

标签: javascript node.js pdf jekyll

我有一个javascript文件应该循环遍历给定目录,索引文件,从中删除前端内容,然后将它们转换为PDF文件。

我的大部分流程都有效,但由于某些原因,我的.replace功能似乎没有做任何事情。

以下是代码:

var fs = require( 'fs' );
var path = require( 'path' );
var process = require( 'process' );
var markdownpdf = require( 'markdown-pdf' )


var md_dir = "_pages";
var pdf_dir = "assets/pdf"

// Loop through all the files in the directory
fs.readdir( md_dir, function( err, files ) {
  if( err ) {
    console.error( "Could not list the directory.", err );
    process.exit( 1 );
  } 

  files.forEach( function( file, index ) {
    // Make one pass and make the file complete
    var md_path = path.join( md_dir, file );
    var pdf_path = path.join( pdf_dir, file + '.pdf' );

    fs.stat( md_path, function( error, stat ) {
      if( error ) {
        console.error( "Error stating file.", error );
        return;
      }

      // Start PDF Process on the files
      if( stat.isFile() ) {
        console.log( "'%s' is a file.", md_path );
        console.log( "Stripping Jekyll Front-Matter...");

        var fileContents = fs.readFileSync(md_path, 'utf8');
        var pattern = /^---\n.*\n---\n/;

        // Strip everything between the first two sets of '---'
        var stripped_md = fileContents.replace( pattern, '' );
        console.log( "Front-Matter stripped." );

        // Pass that to markdown-pdf
        markdownpdf().from.string(stripped_md).to(pdf_path, function () {
          console.log("Created", pdf_path)
        } );
      }

      // If it's not a file
      else if( stat.isDirectory() )
        console.log( "'%s' is a directory.", md_path );

    } );
  } );
} );

1 个答案:

答案 0 :(得分:1)

在正则表达式模式中。 char匹配除换行符之外的所有内容。

FrontMatter有换行符,因此您必须将其添加到模式中。

赞:var pattern = /^---(.|\n)*?---\n/;

其中说明了---"标签"

之间的所有内容或换行符

?让它不贪心