【问题标题】:Gulp Minify Task - TypeError: undefined is not a functionGulp Minify Task - TypeError: undefined is not a function
【发布时间】:2015-08-12 15:01:38
【问题描述】:

我正在使用 AngularJS 构建 Instagram 克隆,并在此处遵循本指南。

https://hackhands.com/building-instagram-clone-angularjs-satellizer-nodejs-mongodb/

我目前处于第 19 节,我正在尝试缩小 JavaScript 文件以提高网站性能。为此,他们建议使用称为 Gulp 的任务运行程序。

在我的 gulpfile.js 中,我声明了我需要的所有依赖项

var gulp = require('gulp');
var csso = require('gulp-csso');
var uglify = require('gulp-uglify');
var concat = require('gulp-concat');
var recess = require('gulp-recess');
var header = require('gulp-header');
var gulpFilter = require('gulp-filter');
var complexity = require('gulp-complexity');
var ngAnnotate = require('gulp-ng-annotate');
var templateCache = require('gulp-angular-templatecache');

我确保它们已通过npm install --save-dev depName 安装在我的package.json 文件中

这是我的缩小任务代码

gulp.task('minify', function() {
    var templatesFilter = gulpFilter('clients/views/*.html');

    return gulp.src([
        'client/vendor/angular.js',
        'client/vendor/*.js',
        'client/app.js',
        'client/templates.js',
        'client/controllers/*.js',
        'client/services/*.js',
        'client/directives/*.js'
    ])
        .pipe(templatesFilter)
        .pipe(templateCache({ root: 'views', module: 'Instagram' }))
        .pipe(templatesFilter.restore())
        .pipe(concat('app.min.js'))
        .pipe(ngAnnotate())
        .pipe(uglify())
        .pipe(header(banner))
        .pipe(gulp.dest('client'));
});

在命令行中,我尝试通过gulp minify运行任务,但得到如下输出

Working directory changed to ~\Documents/tutorials/Angular-Instagram
Using gulpfile ~\Documents\tutorials\Angular-Instagram\gulpfile.js
Starting 'minify'
TypeError: undefined is not a function
at Gulp.<anonymous> (Documents\tutorials\Angular-Instagram\gulpfile.js:34.31)

然后我转到 gulpfile.js 中的第 34 行

.pipe(templatesFilter.restore())

显然它与gulp-filter中的restore()函数有关

按照指南的建议,我在 index.html 文件中注释掉了我的脚本标签

<!--<script src="vendor/angular.js"></script>-->
<!--<script src="vendor/angular-route.js"></script>-->
<!--<script src="vendor/angular-messages.js"></script>-->
<!--<script src="vendor/satellizer.js"></script>-->
<!--<script src="services/api.js"></script>-->
<!--<script src="controllers/home.js"></script>-->
<!--<script src="controllers/navbar.js"></script>-->
<!--<script src="controllers/login.js"></script>-->
<!--<script src="controllers/signup.js"></script>-->
<!--<script src="controllers/detail.js"></script>-->
<!--<script src="directives/serverError.js"></script>-->
<script src="app.min.js"></script>

这是 gulp-filter 的文档

https://www.npmjs.com/package/gulp-filter

有什么想法吗?

【问题讨论】:

    标签: javascript node.js gulp minify


    【解决方案1】:

    如您在文档中所见,请尝试.pipe(templatesFilter.restore)。可能restore不是函数,或者没有直接调用。

    工作解决方案:

    改变这一行: var templatesFilter = gulpFilter('clients/views/*.html', {restore: true});

    【讨论】:

    • 试过了。现在我得到 `TypeError: Cannot read property 'on' of undefined'
    • 也许这会有所帮助。 var templatesFilter = gulpFilter('clients/views/*.html', {restore: true});
    • 用这个解决方案更新了我的初始答案。
    猜你喜欢
    • 2015-06-24
    • 2021-06-21
    • 1970-01-01
    • 2015-10-23
    • 2014-08-15
    • 2015-01-14
    • 2014-07-06
    • 2014-09-01
    • 2020-02-15
    相关资源
    最近更新 更多