gulp插件gulp-nunjucks-render的使用及gulp4的简单了解
之前写过一篇gulp的使用文章一篇迟到的gulp文章,代码合并压缩,less编译
最近有在用gulp,使用到一个gulp-nunjucks-render插件,感觉挺方便的
gulp-nunjucks-render 用来渲染Nunjucks templates
安装
npm install --save-dev gulp-nunjucks-render
使用
var env = process.env.NODE_ENV;
var ver = require('./package.json').version;
var normalUrl = {
'dev': 'http://www.t.xxx.com',
'test': 'http://www.t.xxx.com',
'pre': 'http://www.pre.xxx.com',
'prod': 'https://www.xxx.com',
};
return gulp.src([src + 'pages/**/*.html'])
.pipe(nunjucksRender({
path: [src], // String or Array
manageEnv: manageEnvironment,
data: {
wwwUrl: normalUrl[env]
}
}))
.pipe(gulp.dest(dist))
.pipe(connect.reload());
1、使用data作为一个选项
nunjucksRender({data: {
css_path: 'http://company.com/css/'
}});
<link rel="stylesheet" href="{{ css_path }}test.css" />
编译之后
<link rel="stylesheet" href="http://company.com/css/test.css" />
2、manageEnv用来在编译之前添加filters、globals
var manageEnvironment = function(environment) {
environment.addFilter('getAssetsUrl', function(filename) {
const extname = filename.split('.').pop();
const revJsonFile = path.join(path.dirname(__filename) + '/' + dist, 'public/' + extname + '/rev-manifest.json');
if (fs.existsSync(revJsonFile)) {
const hashMapJson = fs.readFileSync(revJsonFile);
const hashMap = JSON.parse(hashMapJson);
return `${host}/${extname}/${hashMap[filename]}`;
}
});
environment.addFilter('getLibUrl', function(filename) {
return `${host}/lib/${filename}`;
})
environment.addFilter('getVendorUrl', function(filename) {
return `${host}/vendor/${filename}`;
})
environment.addFilter('getImgUrl', function(filename) {
return `https://xxx.xxx.com/www/${imgVer}/pc/img/${filename}`;
})
var newenv = {
'dev': 'development',
'test':'testing',
'pre':'pre',
'prod':'production'
}
environment.addGlobal('env', newenv[env]);
let baseUrl = 'https://www.xxxx.com';
environment.addGlobal('baseUrl', baseUrl);
};
将manageEnvironment添加到manageEnv中
return gulp.src([src + 'pages/**/*.html'])
.pipe(nunjucksRender({
manageEnv: manageEnvironment,
}));
这样在html文件中,通过{{ env }}这种形式拿到全局变量值
<script src="{{ 'nprogress.js' | getVendorUrl }}"></script>
// config
define('config', function () {
return {
env: '{{ env }}',
baseUrl: '{{ baseUrl }}'
};
});
另外,之前一直在用gulp3,今天对gulp4也简单了解了下
gulp4的任务执行
1、在gulp3中,task任务一般都是并行执行,如果需要同步执行需要另外使用插件 run-sequence
2、gulp4中,提供了gulp.series和gulp.parallel任务执行方式
gulp.series 用于串行(顺序)执行
gulp.parallel 用于并行执行
串行、并行执行
const task = gulp.series(clean, gulp.series(copy, js, css), gulp.parallel(html));
function watch(done) {
gulp.watch('src/**/*.*', task);
done();
}
/* m end */
var build = gulp.series(clean, task);
var dev = gulp.series(build, gulp.parallel(watch, serve));
exports.dev = dev;
exports.build = build;
执行命令
gulp dev
gulp build
参考阅读
走进gulp4的世界
Gulp 4: gulp.parallel gulp.series -- 全新的任务执行体系
gulp插件gulp-nunjucks-render的使用及gulp4的简单了解的更多相关文章
- 利用gulp 插件gulp.spritesmith 完成小图合成精灵图,并自动输出样式文件
安装依赖 yarn add gulp yarn add gulp.spritesmith 本次依赖的版本是: "gulp": "^3.9.1" "gu ...
- 常用 Gulp 插件汇总 —— 基于 Gulp 的前端集成解决方案(三)
前两篇文章讨论了 Gulp 的安装部署及基本概念,借助于 Gulp 强大的 插件生态 可以完成很多常见的和不常见的任务.本文主要汇总常用的 Gulp 插件及其基本使用,需要读者对 Gulp 有一个基本 ...
- gulp 插件
原文链接:http://www.mamicode.com/info-detail-517085.html gulp是什么? http://gulpjs.com/ 相信你会明白的! 与著名的构建工具gr ...
- gulp插件gulp-ruby-sass和livereload插件
gulp-ruby-sass是gulp的一个插件,主要是用来实现sass编译,livereload插件主要是实现文件保存时浏览器自动刷新,避免了手动f5的频繁的操作 准备工作:chrome浏览器安装l ...
- gulp插件autoprefixer
gulp的autoprefixer插件可以根据我们的设置帮助我们自动补全浏览器的前缀(如:-moz.-ms.-webkit.-o) 1)首先安装gulp,不知道怎么安装请看这里 2)安装autopre ...
- gulp插件(gulp-jmbuild),用于WEB前端构建
源码地址:https://github.com/jiamao/gulp-jmbuild https://github.com/jiamao/gulp-jmbuild gulp-jmbuild gulp ...
- gulp插件gulp-usemin简单使用
关于什么是gulp,它和grunt有什么区别等问题,这里不做任何介绍.本文主要介绍如何使用gulp-usemin这款插件,同时也会简单介绍本文中用到的一些插件. 什么是gulp-usemin 用来将H ...
- 使用gulp插件来自动刷新页面。
http://itakeo.com/blog/2016/05/19/gulpreload/?none=123 使用gulp插件来自动刷新页面.再也不用修改一次,按一下F5了. 首选通过npm inst ...
- 将less编译成css的gulp插件
简介:gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器:她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成:使用她,我们不仅可以很愉快的编写代码, ...
随机推荐
- Golang的模块管理Module
Golang 1.11版本终于支持了官方的模块依赖管理功能,1.11以前想要实现依赖管理只能够通过借助第三方库来实现,1.11以前的版本Golang项目必须依赖以GOPATH,从当前版本开始Golan ...
- Chrome 启动全屏,并可以F11退出
新建start.bat文件,作用,打开浏览器,并模拟按下F11,全屏,内容如下: start C:\Program" "Files" "(x86)\Google ...
- 我用linux系统的采坑记
我的新Ubuntu18,也没安装什么,但是在使用过程中总是莫名其妙的卡死,真的很烦.有时候cpu使用率接近100%,有时候貌似是内存不够了,但是我明明是8GB,这些小问题搞得我很恼火.这样的机器真的不 ...
- Android Gradle Task
Tasks runnable from root project ------------------------------------------------------------ Androi ...
- css3 js 做一个旋转音乐播放开关
我们经常会看到一些旋转音乐播放开关,今天我也写了一个分享出来,大家需要的话可以参考一下: <!DOCTYPE html> <html lang="en"> ...
- 在React Native中,使用fetch网络请求 实现get 和 post
//在React Native中,使用fetch实现网络请求 /* fetch 是一个封装程度更高的网络API, 使用了Promise * Promise 是异步编程的一种解决方案 * Promise ...
- React-Native的基本控件属性方法,对React-Native的学习,从熟悉基本控件开始。
对React-Native的学习,从熟悉基本控件开始. View 属性方法 序号 名称 属性Or方法 类型 说明 1 accessibilityLabel 属性 string 2 accessib ...
- [Swift]LeetCode553. 最优除法 | Optimal Division
Given a list of positive integers, the adjacent integers will perform the float division. For exampl ...
- Java基础--Eclipse使用
Eclipse是JavaWeb开发最常用的工具,下面详细介绍一下如何下载安装最新版Eclipse.本文eclipse的使用是在JDK安装配置完成的基础上进行的,否则Eclipse安装后可能无法运行程序 ...
- 解决Eclipse中无法查看Java源码
1.点 "window"-> "Preferences"-> "Java" -> "Installed JRES ...