基于gulp的多页应用打包

实现功能主要有

  • 热加载,本地服务器,文件监听,动态刷新
  • 处理图片(优化图片,压缩)
  • 处理scss(压缩合并,兼容前缀,base64,md5,雪碧图,px2rem高清方案)
  • 处理js(模块化开发,压缩合并混淆)
  • html动态更新css,js引用的md5码

项目链接:gulp-multipage

使用方法

1. 依赖安装

- 安装nodejs 本机采用v6.10.1版本
- git clone git@github.com:li2568261/gulp-multipage.git
- 在当前目录下打开命令行(tips:按住shift点击鼠标右键可在菜单处快速打开)
- 运行npm install 等待安装即可

ps:未翻墙的同学建议采用cnpm进行npm install操作

2. 资源代码目录(如果不需要雪碧图功能,请在gulpfile.js文件中的task:pictureInit删除sprite任务,否则会报错):

- 资源目录src


- src的lib目录存放公用资源:


```
目前主要包含三个目录:

commonHtml存放页面公用部分

images存放相关图片,下面得sprite存放合成雪碧图相关图片

js存放js组件,以及一些通用方法

scss存放相关公用样式、组件样式、sprite相关类样式

    ├─commonHtml
    │      header.html
    │      footer.html
    ├─images
    │  └─sprite
    │      ├─a
    │      └─index
    ├─js
    └─scss
```


- pages目录不同的页面新建不同的文件夹,里面都存在相同的目录结构:


```
    在页面当前目录下直接存放html文件命名自取最终导出html文件名与初始命名相同;
    在页面上的js已经scss文件夹分别存放相应的js和样式文件,命名无要求吗,导出文件名称格式为(页面名称).min.[js|css];
    ├─a
    │  │  a.html
    │  ├─images
    │  ├─js
    │  │   a.js
    │  └─scss
    │      a.scss
    └─index
        │  index.html
        ├─images
        ├─js
        │  index.js
        └─scss
           index.scss
```

3. 页面资源配置

参照/config/pagesConfig.js配置,建议遵守demo上的路径配置规则(ps未配置的页面不会进行资源整合处理)

    //以下分别为js和样式文件的别名设置
    var jsFileAlias = {
        jq : path.join(libPath,"/js/jquery-1.9.1.min.js"),
        libjs : path.join(libPath,"/js/lib.js")
    }

    var styleAlias = {
        common : path.join(libPath,"/scss/base.scss"),
        spriteMixin: path.join(libPath,"/scss/sprite-mixin.scss"),
        aSprite : path.join(libPath,"/scss/a-sprite.scss"),
        indexSprite : path.join(libPath,"/scss/index-sprite.scss")
    }
    //allConfig只需要添加需要额外加入的文件;"额外、额外、额外重要的事情说三遍"
    
    //使用雪碧图请加入styleAlias.spriteMixin文件例index项下的import_style,"雪碧图+spriteMixin*3"
    var allConfig = {
        a:{
            import_js:[jsFileAlias.jq,jsFileAlias.libjs],
            import_style:[styleAlias.common]
        },
        index:{
            import_js:[jsFileAlias.jq,jsFileAlias.libjs],
            import_style:[styleAlias.spriteMixin,styleAlias.aSprite]
        }
    }

4. 资源导出目录

资源导出目录dist为文件资源导出目录,需要配合启动服务器进行处理分为两个文件夹,images和pages;images仅存放通用的图片资源。pages目录结构和资源目录一致

5. 代码的编写路径问题

根据代码结构,建议在编写代码的过程中页面独有资源采用相对路径,获取公用资源建议采用绝对路径,绝对路径根目录为dist目录

6. 运行模式

  • 开发

在当前文件根目录下执行命令 npm run dev;
修改src相关文件,dist相关文件也会进行相应更新

  • 发布

在当前文件根目录下执行命令 npm run pub,dist文件即为发布文件

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容

  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,269评论 4 31
  • 在现在的前端开发中,前后端分离、模块化开发、版本控制、文件合并与压缩、mock数据等等一些原本后端的思想开始...
    Charlot阅读 5,424评论 1 32
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,375评论 25 707
  • gulpjs是一个前端构建工具,与gruntjs相比,gulpjs无需写一大堆繁杂的配置参数,API也非常简单,学...
    依依玖玥阅读 3,147评论 7 55
  • http://www.jianshu.com/p/056b1817d25a
    紫色冰雨阅读 138评论 0 0