我正在开发一个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);
答案 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 是该插件的回购。