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

时间:2015-06-17 21:53:37

标签: ember.js ember-cli broccolijs ember-cli-addons

我正在开发一个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);

1 个答案:

答案 0 :(得分:1)

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

使用非常简单,就像:

  

moveFile(inputTree,options)

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

示例:

将单个文件从app / main移动到app:

var moveFile = require('broccoli-file-mover');

var tree = moveFile('app', {
  srcFile: 'app/main.js',
  destFile: '/app.js'
});

将app / main移至app并test / main进行测试:

var moveFile = require('broccoli-file-mover');

var tree = moveFile('app', {
  files: {
    'app/main.js': 'app.js',
    'test/main.js': 'test.js'
  }
});

同样,在blessnm评论之前,broccoli漏斗是一种可能的解决方案,因为您可以将目录复制到您想要的任何地方(认为问题表明移动,但认为复制可能是一种可接受的解决方案), here 是该插件的回购。