在 Ember CLI 项目中使用 Broccoli JS 移动整个文件夹



我正在开发一个ember-cli项目,我正在开发一个系统,该系统允许我解析尚未加载并且可能位于项目结构之外的模板。

我想在我的dist/assets目录中有一个名为 templates 的文件夹,该文件夹内将是来自app/templates/external的所有预编译模板。这是我目前对西兰花炖菜的Brocfile.js尝试

var EmberApp = require('ember-cli/lib/broccoli/ember-app');
var stew = require("broccoli-stew");
var app = new EmberApp({
  vendorFiles: {
    "jquery.js": null
  },
  sassOptions: {
      includePaths: [
        'bower_components/bourbon/app/assets/stylesheets/',
        'bower_components/neat/app/assets/stylesheets/',
        'bower_components/bitters/app/assets/stylesheets/'
      ]
    }
});
var additionalTrees = [];
var templateFiles = stew.find(appTree, "assets/app/templates/external");
templateFiles = stew.mv(templateFiles, "assets/app/templates/external", "assets/templates");
additionalTrees.push(templateFiles);
module.exports = app.toTree(additionalTrees);

有一个名为broccoli-file-mover的npm包,易于使用,可以在这里找到

用法非常简单,简单到:

移动文件(输入树,选项)

可用于移动文件(多个或单个)或整个文件夹

例:

将单个文件从应用程序/主文件移动到应用程序:

var moveFile = require('broccoli-file-mover');
var tree = moveFile('app', {
  srcFile: 'app/main.js',
  destFile: '/app.js'
});
将应用程序/主应用程序移动到

应用程序并将测试/主要移动到测试:

var moveFile = require('broccoli-file-mover');
var tree = moveFile('app', {
  files: {
    'app/main.js': 'app.js',
    'test/main.js': 'test.js'
  }
});

另外,在祝福之前评论西兰花漏斗是一个可能的解决方案,因为您可以将目录复制到您想要的任何地方(认为问题状态移动,但认为复制可能是一个可接受的解决方案),这是插件的存储库。

相关内容

  • 没有找到相关文章