资讯专栏INFORMATION COLUMN

gulp组织小型项目小记

Heier / 2036人阅读

摘要:目前正在开发一个系统,对于前端模块化与打包这块出现了一些选择。采用模块化及打包由于项目比较小,稍微了解后,觉得没必要采用。组件化,目前比较流行的如等。项目较小需要交互更新页面的并不多,没有采用。

目前正在开发一个python markdown wiki系统,对于前端模块化与打包这块出现了一些选择。
1、采用webpack模块化及打包
由于项目比较小,稍微了解后,觉得没必要采用webpack。杀鸡焉用牛刀?
2、采用requirejs模块化,gulp打包
还是由于项目比较小,甚至不需要进行模块化,所以放弃采用requirejs,只是采用gulp进行打包。
3、css预编译框架,目前比较流行的有sass,less:目前没有采用,下一步尝试一下。
4、js组件化,目前比较流行的如Angular,VueJs等。项目较小,需要ajax交互更新页面的并不多,没有采用。部分功能用模板引擎的宏来实现。

当然采用gulp打包主要是为了解决以下几个问题:
1、js、css文件压缩与合并
2、js、css缓存与版本问题

关于js、css缓存与版本问题问题,目前为解决新版本发布,使得浏览器缓存发送新的请求而不是使用缓存的js,css文件。有两种方案:

app.js变为app-2qwee.js

app.js变为app.js?v=wqe2434er3

我比较喜欢的是后者方式。
gulp有个插件gulp-version-number可以解决这个问题,但是由于我采用模板引擎jinja2与flask框架开发,所以html中是这样的


经过gulp-version-number编译后变成了


而我期望的是

好奇的你肯定会问,为什么期望的不是这样呢?
url_for("static", filename="app.css?v=16124df4fdca2e5244636c2bca625276") }}"
经实验,经过url_for输出结果中?变成了%3F,经过了urlencode,所以浏览器无法识别它为查询参数。

没办法,只能改改这个插件的源码:具体代码在插件代码的index.js处:大概在207-284行部分:
主要改动就是替换sts[i].match正则,加入_RULE长度判断。

   var appendto = {
        "css": function (content, k, v) {
            var sts = content.match(/]*rel=[""]?stylesheet[""]?[^>]*>/g);
            
            if (util.isArray(sts) && sts.length) {
                for (var i = 0, len = sts.length; i < len; i++) {
                    
                    //var _RULE = sts[i].match(/href=[""]?([^>""]*)[""]?/);
                    var _RULE=sts[i].match(/({{surl_for("static",s?filename=[""].*?[""]s?)s}})/);
                    if(!_RULE||_RULE.length<2){
                        continue;
                    }
                    console.log(sts[i]);
                    console.log(_RULE[1]);
                    if (_RULE[1]) {
                        var _UrlPs = parseURL(_RULE[1]);
                        var _Query = queryToJson(_UrlPs.query);
                        var _Append = {};
                        if (!_Query.hasOwnProperty(k) || this["cover"]) {
                            _Append[k] = v;
                        }
                        _UrlPs.query = jsonToQuery(util._extend(_Query, _Append));
                        content = content.replace(sts[i], sts[i].replace(_RULE[1], renderingURL(_UrlPs)));
                    }
                }
            }
            return content;
        },
        "js": function (content, k, v) {
            var sts = content.match(/]*src=[""]?([^>""]*)[""]?[^>]*>[^<]*/g);
            if (util.isArray(sts) && sts.length) {
                for (var i = 0, len = sts.length; i < len; i++) {
                    var _RULE = sts[i].match(/({{surl_for("static",s?filename=[""].*?[""]s?)s}})/);//.match(/src=[""]?([^>""]*)[""]?/);
                    if(!_RULE||_RULE.length<2){
                        continue;
                    }
                    console.log(sts[i]);
                    console.log(_RULE[1]);
                    
                    if (_RULE[1]) {
                        var _UrlPs = parseURL(_RULE[1]);
                        var _Query = queryToJson(_UrlPs.query);
                        var _Append = {};
                        if (!_Query.hasOwnProperty(k) || this["cover"]) {
                            _Append[k] = v;
                        }
                        _UrlPs.query = jsonToQuery(util._extend(_Query, _Append));
                        content = content.replace(sts[i], sts[i].replace(_RULE[1], renderingURL(_UrlPs)));
                    }
                }
            }
            return content;
        },
        "image": function (content, k, v) {
            var sts = content.match(/]*>/g);
            if (util.isArray(sts) && sts.length) {
                for (var i = 0, len = sts.length; i < len; i++) {
                    var _RULE = sts[i].match(/({{surl_for("static",s?filename=[""].*?[""]s?)s}})/);//.match(/src=[""]?([^>""]*)[""]?/);
                    if(!_RULE||_RULE.length<2){
                        continue;
                    }
                    console.log(sts[i]);
                    console.log(_RULE[1]);
                    if (_RULE[1]) {
                        var _UrlPs = parseURL(_RULE[1]);
                        var _Query = queryToJson(_UrlPs.query);
                        var _Append = {};
                        if (!_Query.hasOwnProperty(k) || this["cover"]) {
                            _Append[k] = v;
                        }
                        _UrlPs.query = jsonToQuery(util._extend(_Query, _Append));
                        content = content.replace(sts[i], sts[i].replace(_RULE[1], renderingURL(_UrlPs)));
                    }
                }
            }
            return content;
        }
    };

然后,项目主要配置文件如下:不多说,具体看配置
package.json

{
  "name": "mdwiki",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo "Error: no test specified" && exit 1"
  },
  "author": "xbynet",
  "license": "ISC",
  "devDependencies": {
    "del": "^2.2.2",
    "gulp": "^3.9.1",
    "gulp-autoprefixer": "^3.1.1",
    "gulp-clean": "^0.3.2",
    "gulp-concat": "^2.6.1",
    "gulp-flatten": "^0.3.1",
    "gulp-minify-css": "^1.2.4",
    "gulp-rev": "^7.1.2",
    "gulp-sourcemaps": "^1.9.1",
    "gulp-uglify": "^2.0.0",
    "gulp-version-number": "^0.1.5",
    "pump": "^1.0.1",
    "run-sequence": "^1.2.2"
  }
}

gulpfile.js

const gulp = require("gulp");
const uglify = require("gulp-uglify");
const pump = require("pump");
const version = require("gulp-version-number");
const autoprefixer = require("gulp-autoprefixer");
const sourcemaps=require("gulp-sourcemaps");
const runSequence = require("run-sequence");
const del = require("del");
const cssmin = require("gulp-minify-css");
//const imagemin = require("gulp-imagemin");
const clean = require("gulp-clean");
//const flatten = require("gulp-flatten");
const DEST_DIR="build";
const SRC_DIR="mdwiki-master/app";
// Environment setup.
var env = {
    production: false
};

// Environment task.
gulp.task("set-production", function(){
    env.production = true;
});

const versionConfig = {
  "value": "%MDS%",
  "append": {
    "key": "v",
    "to": ["css", "js","image"],
  },
};

gulp.task("html",()=>{
    return gulp.src(SRC_DIR+"/**/*.html")
    .pipe(version(versionConfig))
    .pipe(gulp.dest(DEST_DIR));
});
gulp.task("jsmin", function (cb) {
    if(env.production){
        return gulp.src([SRC_DIR+"/**/*.js"])
        .pipe(uglify({mangle: {except: ["require" ,"exports" ,"module" ,"$"]}})) //排除混淆关键字
        .pipe(gulp.dest(DEST_DIR));
    }
    else{
        return gulp.src([SRC_DIR+"/**/*.js"])
        .pipe(sourcemaps.init())
        .pipe(uglify({mangle: {except: ["require" ,"exports" ,"module" ,"$"]}})) //排除混淆关键字
        .pipe(sourcemaps.write("."))
        .pipe(gulp.dest(DEST_DIR));
    }
    
});
gulp.task("cssmin", function () {
    if(env.production){
        return gulp.src(SRC_DIR+"/**/*.css")
        //.pipe(concat("main.css"))
        .pipe(autoprefixer("last 2 version", "safari 5", "ie 8", "ie 9", "opera 12.1", "ios 6", "android 4"))
        .pipe(cssmin())
        .pipe(gulp.dest(DEST_DIR));
    }
    else{
        return gulp.src(SRC_DIR+"/**/*.css")
        //.pipe(concat("main.css"))
        .pipe(autoprefixer("last 2 version", "safari 5", "ie 8", "ie 9", "opera 12.1", "ios 6", "android 4"))
        .pipe(sourcemaps.init())
        
        .pipe(cssmin())
        .pipe(sourcemaps.write("."))
        .pipe(gulp.dest(DEST_DIR));
    }
    
});
gulp.task("rawtoone", () =>{
    return gulp.src([SRC_DIR+"/**/*.{png,jpg,jpeg,gif,bmp,ico}",SRC_DIR+"/**/*.{swf,eot,svg,ttf,woff}"])
        .pipe(flatten())
        //.pipe(imagemin())
        .pipe(gulp.dest(DEST_DIR));
    }
);
gulp.task("copy", () =>{
    return gulp.src([SRC_DIR+"/**/*.{png,jpg,jpeg,gif,bmp,ico}",SRC_DIR+"/**/*.{swf,eot,svg,ttf,woff}"])
        .pipe(gulp.dest(DEST_DIR));
    }
);
// Clean
gulp.task("clean", function(cb) {
   return  del(["./build"],cb);
      // return gulp.src("build", {read: false,force: true})
      //  .pipe(clean());
});
// Default task
gulp.task("dev",function(callback) {
    runSequence("clean",["html", "jsmin","cssmin","copy"],callback);
});

gulp.task("product",function(callback) {
    runSequence("set-production","clean",["html", "jsmin","cssmin","copy"],callback);
});
gulp.task("watch", function() {
  gulp.watch(SRC_DIR+"/**/*.html",["html"]);
  gulp.watch(SRC_DIR+"/**/*.js", ["jsmin"]);
  gulp.watch(SRC_DIR+"/**/*.css", ["cssmin"]);
  gulp.watch([SRC_DIR+"/**/*.{png,jpg,jpeg,gif,bmp,ico}",SRC_DIR+"/**/*.{swf,eot,svg,ttf,woff}"],["copy"]);
  // Create LiveReload server
  //livereload.listen();
  // Watch any files in dist/, reload on change
  //gulp.watch(["dist/**"]).on("change", livereload.changed);
});

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/44307.html

相关文章

  • gulp组织小型项目小记

    摘要:目前正在开发一个系统,对于前端模块化与打包这块出现了一些选择。采用模块化及打包由于项目比较小,稍微了解后,觉得没必要采用。组件化,目前比较流行的如等。项目较小需要交互更新页面的并不多,没有采用。 目前正在开发一个python markdown wiki系统,对于前端模块化与打包这块出现了一些选择。1、采用webpack模块化及打包由于项目比较小,稍微了解后,觉得没必要采用webpack...

    2json 评论0 收藏0
  • mdwiki开发之路一技术选型

    摘要:是一款系统,可以作为个人或小型团队的知识库管理系统。再加上目前开始学习与爬虫。技术选型作为新手,义不容辞为什么就为了原生支持开玩笑因为代表了的未来,而且越来越多的库已经迁移到了,没有什么理由不选择它。 mdwiki是一款markdown wiki系统,可以作为个人或小型团队的知识库管理系统。项目地址:本系列文章最后一篇给出(需要时间整理和测试) 为什么我要开发mdwiki? 目前本人的...

    pubdreamcc 评论0 收藏0
  • mdwiki开发之路一技术选型

    摘要:是一款系统,可以作为个人或小型团队的知识库管理系统。再加上目前开始学习与爬虫。技术选型作为新手,义不容辞为什么就为了原生支持开玩笑因为代表了的未来,而且越来越多的库已经迁移到了,没有什么理由不选择它。 mdwiki是一款markdown wiki系统,可以作为个人或小型团队的知识库管理系统。项目地址:本系列文章最后一篇给出(需要时间整理和测试) 为什么我要开发mdwiki? 目前本人的...

    李昌杰 评论0 收藏0
  • gulp4.0升级小记

    摘要:前言周日在公司的新电脑在以前配置的目录按下时发现报了错,百度了一下得知原来已经到了版本,就花了一点时间去升了个级,顺便记下我个人使用到的配置文件新版本的不同点,文笔和水平有限,多多见谅新引入新引入的可替换老版的和,代码更简洁是任务监听是任务 前言 周日在公司的新电脑在以前gulp3.9配置的目录按下npm install时发现报了错,百度了一下得知原来gulp已经到了4.0版本,就花了...

    zorpan 评论0 收藏0
  • 一篇 NPM 常见问题小记

    摘要:常见问题的中的和会匹配最近的小版本依赖包,比如会匹配所有版本,但是不包括会匹配最新的大版本依赖包,比如会匹配所有的包,包括,但是不包括你也有可能会看见在中模块的版本号前面既没有也没有就像下面那样上面的情况属于精确安装模块指定的版本号。 常见问题 1.npm 的package.json中的~和^ ~会匹配最近的小版本依赖包,比如~1.2.3会匹配所有1.2.x版本,但是不包括1.3.0...

    lvzishen 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<