19

我正在使用gulp-angular-templatecache生成一个 templateCache.js 文件,该文件将我所有的 HTML 模板文件合并为 1。(我的完整 gulpfile

将该新模块注入我的应用程序后,我的指令将自动获取模板,我不需要将部分 .html 文件添加到我的构建文件夹中。

问题是主要文件夹路径被切断,请参见下面的示例:

我的指令中的路径:

templateUrl : "panels/tags/tagsPanel.html"...
templateUrl : "header/platform_header/platformHeader.html"...

我生成的 templateCache 文件中的路径:

$templateCache.put("tags/tagsPanel.html"...
$templateCache.put("platform_header/platformHeader.html"...

^panels并且header正在迷路。

在此处输入图像描述


我正在尝试编写一个可以在我的 Gulpfile 中修复该问题的函数。

我的Gulpfile的配置部分:

var config = {
    srcPartials:[
        'app/beta/*.html', 
        'app/header/**/*.html',
        'app/help/*.html',
        'app/login/*.html',
        'app/notificaitons/*.html',
        'app/panels/**/*.html',
        'app/popovers/**/*.html',
        'app/popovers/*.html',
        'app/user/*.html',
        'app/dashboard.html'
    ],
    srcPaths:[
        'beta/', 
        'header/',
        'help/',
        'login/',
        'notificaitons/',
        'panels/',
        'popovers/',
        'popovers/',
        'user/',
        'dashboard.html'
    ],
    destPartials: 'app/templates/'
};

我的html-templatesgulp.task

gulp.task('html-templates', function() {
    return gulp.src(config.srcPartials)
    .pipe(templateCache('templateCache.js', {
        root: updateRoot(config.srcPaths)
    },
    { module:'templateCache', standalone:true })
    ).pipe(gulp.dest(config.destPartials));
});

function updateRoot(paths) {
    for (var i = 0; i < paths.length; i++) {
        // console.log(paths);
        console.log(paths[i]);
        return paths[i];
    }
}

^ 以上是有效的,因为它使用gulp-angular-templatecache中的root 选项在模板路径前面附加一个新字符串。

问题是我上面的代码返回一次并更新路径数组中第一项的所有路径,即beta/.

您将如何编写它以正确替换每个文件的路径?

4

3 回答 3

15

弄清楚了!我不应该使用确切的文件夹名称,而是**在我的配置中使用 glob

var config = {
    srcTemplates:[
        'app/**/*.html',            
        'app/dashboard.html',
        '!app/index.html'
    ],
    destPartials: 'app/templates/'
};

更新后的 gulp.task:

gulp.task('html-templates', function() {
    return gulp.src(config.srcTemplates)
    .pipe(templateCache('templateCache.js', { module:'templateCache', standalone:true })
    ).pipe(gulp.dest(config.destPartials));
});

现在输出是正确的:

$templateCache.put("beta/beta.html"...
$templateCache.put("header/control_header/controlHeader.html"...
$templateCache.put("panels/tags/tagsPanel.html"...
于 2015-07-16T15:54:14.787 回答
5

我遇到了类似的问题,但就我而言,不可能对所有 gulp.src 条目使用相同的目录。

有一个适用于所有这些文件夹的解决方案

return gulp.src(['public/assets/app1/**/*.tpl.html', 'public/assets/common_app/**/*.tpl.html'])
    .pipe(templateCache({
        root: "/",
        base: __dirname + "/public",
        module: "App",
        filename: "templates.js"
    }))
    .pipe(gulp.dest('public/assets/templates'))

这假定 gulpfile 是公共目录的上一级目录。它将从 src 文件的完整路径中删除基本字符串。Base 也可以是一个将传递文件对象的函数,这在更复杂的情况下可能会有所帮助。它在 gulp-angular-templatecache 中 index.js 的第 60 行左右

于 2016-04-08T18:03:50.867 回答
1

您还可以使用这个 gulp 插件,它可以读取您的路由、指令并将 templateUrl 替换为 templateUrl 中引用的模板。

这将消除有关在应用程序中处理 templateUrl 的所有麻烦。这使用相对 url 来指示 js 文件,而不是绝对 url。

src
+-hello-world
  |-hello-world-directive.js
  +-hello-world-template.html

你好世界directive.js:

angular.module('test').directive('helloWorld', function () {
    return {
        restrict: 'E',
        // relative path to template
        templateUrl: 'hello-world-template.html'
    };
});

你好世界模板.html:

<strong>
    Hello world!
</strong>

gulpfile.js:

var gulp = require('gulp');
var embedTemplates = require('gulp-angular-embed-templates');

gulp.task('js:build', function () {
    gulp.src('src/scripts/**/*.js')
        .pipe(embedTemplates())
        .pipe(gulp.dest('./dist'));
});

gulp-angular-embed-templates 将生成以下文件:

angular.module('test').directive('helloWorld', function () {
    return {
        restrict: 'E',
        template:'<strong>Hello world!</strong>'
    };
});
于 2016-07-16T09:51:31.383 回答