Gulp Minify Task - TypeError: undefined is not a function
Gulp Minify Task - TypeError: undefined is not a function
我正致力于在 AngularJS 中构建 Instagram 克隆,并在此处遵循本指南。
https://hackhands.com/building-instagram-clone-angularjs-satellizer-nodejs-mongodb/
我目前在第 19 部分,我正在尝试缩小 JavaScript 文件以提高网站性能。为此,他们建议使用名为 Gulp
.
的任务 运行ner
在我的 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
有什么想法吗?
尝试 .pipe(templatesFilter.restore)
,如您在文档中所见。可能restore
不是函数,或者没有直接调用
工作解决方案:
更改此行:
var templatesFilter = gulpFilter('clients/views/*.html', {restore: true});
我正致力于在 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
有什么想法吗?
尝试 .pipe(templatesFilter.restore)
,如您在文档中所见。可能restore
不是函数,或者没有直接调用
工作解决方案:
更改此行:
var templatesFilter = gulpFilter('clients/views/*.html', {restore: true});