基于nodejs的雪碧图制作工具的示例代码


Posted in NodeJs onNovember 05, 2018

前颜(yan)

雪碧图(CSS sprite ),就是把很多小图标合并为一张图片。

在Web开发中,使用雪碧图是优化Web性能的一种方法。

比如你可能遇到过这样的一种场景:在你的页面中,使用到了很多的小图标,然后你的每个小图标都是通过 <img src='logo.png'>来引用的。

通过这种方式虽然比较方便,但是存在的一个缺点就是性能问题,即浏览器在解析每个小图标时,都要发起一次http或(https)请求,而这个小图标本身却很小,可能只有十几k甚至几k,那么为每个小图标单独发起http请求,其实有点资源浪费。

为什么会资源浪费呢?

浏览器在与服务器进行http请求的过程中,需要有一个类似握手通信的过程,然后才是真正的获取数据。

举个例子,在这里我把浏览器发起的http图片请求简单分为两个过程,分别为:

1、浏览器与服务器的通信握手过程,假设耗时X ms(毫秒)

2、真正的数据获取过程,假设耗时 Y ms(毫秒)

那么浏览器发起一次http请求的总耗时为:sum(1)=X+Y ms,由于小图标数据很小,可能只有几k,因此通信过程的耗时X是大于Y的。

而当你在网页中引用了很多小图标时,假设有n个小图标,此时总耗时为sum(n)=nX+nY ms,通过对比sum(1)和sum(n),你就会发现,上面所说的资源浪费主要是在于通信握手的时间Y。此时,我就会想,如果我一次性取得所有的小图标,那么总耗时就变成了sum(n)=nX+Y ms,这样就能节省(n-1)Y的http握手通信的时间开销,从而优化了web的响应性能。

一、雪碧图抠图(background-position)

通过前面的介绍,我们知道,雪碧图的原理就是将页面中使用到的小图标合成为一张总图。这样的话当我们想要使用雪碧图中的某一个小图标,应该通过如何实现呢?

答案是通过css的background-position,background-position的默认坐标是(0,0),关于background-position的详细使用,大家可以网上搜索一下,资料很多。(这次主要讲雪碧图制作工具)

二、雪碧图制作工具 simple-sprite

那么如何合成雪碧图呢?怎样才能更方便的合成雪碧图呢?

因为懒,我的想法是,每次当我需要合成雪碧图时,我只要经过以下尽量简单的步骤就可以快速合成,并且可以导出各个小图标在雪碧图中的background-position css样式。为此,我用nodejs写了一个雪碧图制作工具:simple-sprite,并打包生成npm包发布至npm官网。

雪碧图制作步骤如下:

1 创建雪碧图生成工程

mkdir sprite-generator
cd sprite-generator

2 初始化工程

npm init

3 把所有小图标放到imgs中

mkdir imgs && 把所有的小图标放到imgs中

4 下载simple-sprite npm包

npm install --save simple-sprite

5 运行生成雪碧图

let sprite = require('simple-sprite');

sprite.generateSprite('./imgs');

simple-sprite:https://www.npmjs.com/package/simple-sprite

三、github源码

构建工具:rollup

github源码:https://github.com/SimpleCodeCX/simple-sprite#readme

(如果你点开了我的github源码连接,顺便也帮我点个star哦!哈哈)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
基于NodeJS的前后端分离的思考与实践(三)轻量级的接口配置建模框架
Sep 26 NodeJs
Nodejs为什么选择javascript为载体语言
Jan 13 NodeJs
Nodejs多站点切换Htpps协议详解及简单实例
Feb 23 NodeJs
详解nodejs爬虫程序解决gbk等中文编码问题
Apr 06 NodeJs
nodejs入门教程五:连接数据库的方法分析
Apr 24 NodeJs
win系统下nodejs环境安装配置
May 04 NodeJs
nodejs中art-template模板语法的引入及冲突解决方案
Nov 07 NodeJs
nodejs使用redis作为缓存介质实现的封装缓存类示例
Feb 07 NodeJs
nodejs制作小爬虫功能示例
Feb 24 NodeJs
Nodejs + sequelize 实现增删改查操作
Nov 07 NodeJs
如何利用nodejs实现命令行游戏
Nov 24 NodeJs
Node.js实现爬取网站图片的示例代码
Apr 04 NodeJs
nodejs遍历文件夹下并操作HTML/CSS/JS/PNG/JPG的方法
Nov 01 #NodeJs
nodejs中函数的调用实例详解
Oct 31 #NodeJs
NodeJS 将文件夹按照存放路径变成一个对应的JSON的方法
Oct 17 #NodeJs
Nodejs实现多文件夹文件同步
Oct 17 #NodeJs
深入理解NodeJS 多进程和集群
Oct 17 #NodeJs
CentOS7中源码编译安装NodeJS的完整步骤
Oct 13 #NodeJs
NodeJS加密解密及node-rsa加密解密用法详解
Oct 12 #NodeJs
You might like
php Smarty date_format [格式化时间日期]
2010/03/15 PHP
PHP常用特殊运算符号和函数总结(php新手入门必看)
2013/02/02 PHP
jquery判断单个复选框是否被选中的代码
2009/09/03 Javascript
js设置组合快捷键/tabindex功能的方法
2013/11/21 Javascript
JS Loading功能的简单实现
2013/11/29 Javascript
js函数调用的方式
2014/05/06 Javascript
浅谈jQuery中 wrap() wrapAll() 与 wrapInner()的差异
2014/11/12 Javascript
浅谈jQuery操作类数组的工具方法
2016/12/23 Javascript
JavaScript模块化之使用requireJS按需加载
2017/04/12 Javascript
JavaScript实现body内任意节点的自定义属性功能示例
2017/09/18 Javascript
浅谈angular2路由预加载策略
2017/10/04 Javascript
vue2.0 根据状态值进行样式的改变展示方法
2018/03/13 Javascript
Vue不能观察到数组length的变化
2018/06/08 Javascript
微信小程序开发之路由切换页面重定向问题
2018/09/18 Javascript
详解KOA2如何手写中间件(装饰器模式)
2018/10/11 Javascript
JS实现的类似微信聊天效果示例
2019/01/29 Javascript
微信小程序页面间跳转传参方式总结
2019/06/13 Javascript
Vue实现数据请求拦截
2019/10/23 Javascript
python 定时修改数据库的示例代码
2018/04/08 Python
python3实现163邮箱SMTP发送邮件
2018/05/22 Python
在pycharm中设置显示行数的方法
2019/01/16 Python
Python list运算操作代码实例解析
2020/01/20 Python
tensorflow 2.0模式下训练的模型转成 tf1.x 版本的pb模型实例
2020/06/22 Python
用python给csv里的数据排序的具体代码
2020/07/17 Python
深入浅析HTML5中的SVG
2015/11/27 HTML / CSS
巴西独家产品和现场演示购物网站:Shoptime
2019/07/11 全球购物
写给妈妈的道歉信
2014/01/11 职场文书
浙大毕业生自荐信
2014/01/26 职场文书
外贸员简历中的自我评价
2014/03/04 职场文书
经典商业广告词
2014/03/13 职场文书
道路建设实施方案
2014/03/18 职场文书
市场策划求职信
2014/08/07 职场文书
户籍证明格式
2014/09/15 职场文书
Python初识逻辑与if语句及用法大全
2021/08/07 Python
Ajax实现异步加载数据
2021/11/17 Javascript
Redis中缓存穿透/击穿/雪崩问题和解决方法
2021/12/04 Redis