繁体   English   中英

如何使用Node自定义此构建脚本?

[英]How can I customize this build script with Node?

我有一个独特的目录结构,我需要帮助来制作构建脚本。
这是链接 (略有不同)或目录结构:

client
  /extensions
  /sandbox
  /widgets
    /form
      /collections
      /models
      /views
      /styles
        custom.css
      /controllers
  main.coffee
server
  /views
    /layouts
    /errors
  app.coffee
  config.coffee

我需要的几件事情:

  • 将带有监视任务的coffeescript编译为server-dist + client-dist
  • 将所有其他文件复制到它们的嵌套文件夹中,最好同时执行监视任务

问题:

  • 如果我只是编译coffeescript,它只是将.coffee文件复制到.js到它们的嵌套目录中,但是留下了装有require.js的.css / imgs / etc。 我需要一种将它们也带入-dist目录的方法
  • / client文件夹中的Main.coffee是require.config,可以与requirejs grunt构建工具一起使用来优化内容。

无论如何,最简单的解决方案就是我想要的。

我最终使用grunt-完成以下任务:

  • clean :清除服务器/客户端构建目录
  • watch :监视.coffee文件和两个构建目录
  • 复制 :复制客户端/服务器文件以建立目录,而忽略由coffee任务管理的.coffee文件
  • coffee :将.coffee文件编译为.js,将其移动到构建目录

这是当前迭代中的grunt文件:

grunt.initConfig({

 clean: {
   build: ['client-dist', 'server-dist'],
   release: []
 },

 watch: {
   coffee: {
     files: ['client/**/*.coffee', 'server/**/*.coffee'],
     tasks: 'coffee reload'
   },
   reload: {
     files: ['client/**/*.!(coffee)', 'server/**/*.!(coffee)'],
     tasks: 'copy reload'
   }
 },

 copy: {
   client: {
     files: {
       "client-dist/": "client/**/*.!(coffee)"
     },
     options: {
       basePath: "client"
     }
   },
   server: {
     files: {
       "server-dist/": "server/**/*.!(coffee)"
     },
     options: {
       basePath: "server"
     }
   }
 },

 coffee: {
   compile: {
     files: {
       'server-dist/*.js': 'server/**/*.coffee',
       'client-dist/*.js': 'client/**/*.coffee'
       }
     }
 }

});

grunt.loadNpmTasks('grunt-contrib');
grunt.loadNpmTasks('grunt-reload');

grunt.registerTask('default', '');
grunt.registerTask('build', 'clean:build copy coffee watch');

暂无
暂无

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

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