马上圣诞节了,作为一名程序猿,如何体现自己独特的过节风格,如何在朋友圈发一张专属自己的祝福照片我觉得很有必要,你们说是不是。

谈到圣诞节,话说程序猿和圣诞之间的关系还有这么一个笑话:

Q:程序员为什么总是将万圣节和圣诞节弄混?

A:因为oct 31==Dec 25!

停停停...

先不笑,咱们先冷静下...

面对圣诞节还得加班加点的苦逼程序猿们,我们来缓解下自己沉闷的心情,发挥下自己独特的艺术细胞,是时候装一下逼了...

那就让我们用手头的IDE工具来展示一颗圣诞树吧,没有圣诞老人,没有圣诞礼物,咱们有圣诞树。

瞧,出来了,不是一棵,是一坨。

↓↓↓↓↓↓↓↓↓↓

所有的js代码都堆成树了....

关键是还是自动生成的!

这咋搞?咋搞?

下面就和大家一起分享:

首先这并非小编原创,之前便有牛逼的大神创造了这一款工具,它叫js2image。

js2image 是一个可以把js源代码压缩成一个ascii字符画的源代码的工具,它的特色是压缩后的代码仍可运行,而不是简单的拼成最终的图案哦。

安装了node和npm的童鞋可以直接使用以下命令安装js2image:

安装完毕后执行命令:

其中的路径./resource/jquery.js为你所要压缩js的文件路径

执行完命令后会生成一个xmas.js结尾的文件,打开来可以看到一棵棵圣诞树咯。

其他安装方法可详见:

据说压缩完了99%的代码都可以正常运行哦。

哈哈哈,有兴趣的童鞋可以尝试下,

今年圣诞咱们就和圣诞树(还是代码)过吧~

PS:js的 new image()

创建一个Image对象:var a=new Image();    定义Image对象的src: a.src=”xxx.gif”;    这样做就相当于给浏览器缓存了一张图片。

图像对象:

建立图像对象:图像对象名称=new Image([宽度],[高度])

图像对象的属性: border complete height hspace lowsrc name src vspace width

图像对象的事件:onabort onerror onkeydown onkeypress onkeyup onload

需要注意的是:src 属性一定要写到 onload 的后面,否则程序在 IE 中会出错。

参考代码:

var img=new Image();

img.οnlοad=function(){alert("img is loaded")};

img.οnerrοr=function(){alert("error!")};

img.src="http://www.abaonet.com/img.gif";

function show(){alert("body is loaded");};

window.οnlοad=show;

运行上面的代码后,在不同的浏览器中进行测试,发现 IE 和 FF 是有区别的,在 FF 中,img 对象的加载包含在 body

的加载过程中,既是 img加载完之后,body 才算是加载完毕,触发 window.onload 事件。

在 IE 中,img 对象的加载是不包含在 body 的加载过程之中的,body 加载完毕,window.onload 事件触发时,img

对象可能还未加载结束,img.onload事件会在 window.onload 之后触发。

根据上面的问题,考虑到浏览器的兼容性和网页的加载时间,尽量不要在 Image 对象里放置过多的图片,否则在 FF 下

会影响网页的下载速度。当然如果你在 window.onload 之后,执行预加载函数,就不会有 FF 中的问题了。

可以通过Image对象的complete 属性来检测图像是否加载完成(每个Image对象都有一个complete属性,当图像处于

装载过程中时,该属性值false,当发生了onload、onerror、onabort中任何一个事件后,则表示图像装载过程结束(不管成

没成功),此时complete属性为true)

var img = new Image();

img.src = oImg[0].src = this.src.replace(/small/,"big");

oDiv.style.display = "block";

img.complete ? oDiv.style.display = "none" : (oImg[0].onload = function() {oDiv.style.display = "none"})

注:

ie 火狐等大众浏览器均支持 Image对象的onload事件。

ie8及以下、opera 不支持onerror事件

时间: 2015-12-21

html和js画圣诞树图片,基于JS2Image实现圣诞树代码相关推荐

  1. html和js画圣诞树图片,基于JS2Image实现圣诞树代码,

    基于JS2Image实现圣诞树代码, 马上圣诞节了,作为一名程序猿,如何体现自己独特的过节风格,如何在朋友圈发一张专属自己的祝福照片我觉得很有必要,你们说是不是. 谈到圣诞节,话说程序猿和圣诞之间的关 ...

  2. python圣诞树代码成品图片动态_基于JS2Image实现圣诞树代码

    马上圣诞节了,作为一名程序猿,如何体现自己独特的过节风格,如何在朋友圈发一张专属自己的祝福照片我觉得很有必要,你们说是不是. 谈到圣诞节,话说程序猿和圣诞之间的关系还有这么一个笑话: Q:程序员为什么 ...

  3. html上传图片裁剪,基于HTML5+JS实现本地图片裁剪并上传功能

    基于HTML5+JS实现本地图片裁剪并上传功能 2019-01-07 编程之家 https://www.jb51.cc 编程之家收集整理的这篇文章主要介绍了基于HTML5+JS实现本地图片裁剪并上传功 ...

  4. 用python绘制彩色圣诞树简笔画图片大全_圣诞树图片简笔画彩色

    圣诞树图片简笔画彩色 圣诞树是圣诞节庆祝活动的一部分,也是圣诞节上不可少的主角之一.以下是小编整理的圣诞树图片简笔画彩色,欢迎阅读. 圣诞树图片简笔画彩色1 圣诞树图片简笔画彩色2 圣诞树图片简笔画彩 ...

  5. 基于vue + axios + lrz.js 微信端图片压缩上传

    业务场景 微信端项目是基于Vux + Axios构建的,关于图片上传的业务场景有以下几点需求: 1.单张图片上传(如个人头像,实名认证等业务) 2.多张图片上传(如某类工单记录) 3.上传图片时期望能 ...

  6. 简单python画圣诞树图片-python圣诞树代码

    python圣诞树代码 1.简单的绘制圣诞树 新建tree1.py或者直接输入下面代码运行#声明树的高度 height = 5 #树的雪花数,初始为1 stars = 1 #以数的高度作为循环次数 f ...

  7. 简单python画圣诞树图片-python圣诞树编写实例详解

    python圣诞树代码 1.简单的绘制圣诞树 新建tree1.py或者直接输入下面代码运行 #声明树的高度 height = 5 #树的雪花数,初始为1 stars = 1 #以数的高度作为循环次数 ...

  8. d3.js画柱状图超详细教程

    d3.js画柱状图超详细教程 完整代码下载链接:https://download.csdn.net/download/qq5q13638/85248934,直接用这个文件夹内打开即可. 下面是完整教程 ...

  9. html图片自动切换的幻灯片效果的,js带点自动图片轮播幻灯片特效代码分享

    本文实例讲述了javascript带点自动图片轮播幻灯片特效.分享给大家供大家参考.具体如下: 这是一款基于javascript实现带点自动图片轮播幻灯片特效代码,实现过程很简单. 运行效果图:--- ...

最新文章

  1. 基于Centos7的autobahn-python+crossbar的环境搭建
  2. 你必须掌握足够的知识来明确如何拥有自己的观点。同时,也要培养把自己的观点付诸现实的能力。...
  3. 7-2 旅行售货员 (10 分)(TSP问题思路加详解)
  4. curl -windows下接口通讯
  5. oracle中dbms_如何在DBMS中找到关系的最高范式?
  6. java 采集 cms_开源 java CMS - FreeCMS2.3 Web页面信息采集
  7. (转)分布式文件存储FastDFS(二)FastDFS安装
  8. RunAs 增强性扩展命令(支持自动提交密码,安全授权)
  9. 飞行管理计算机在ATA章节,民航ATA章节中英文对照.docx
  10. 重改破解易支付码支付V5.0源码
  11. codesys file读写配置参数程序
  12. WebUploader 设置单个图片上传
  13. 2022码支付个人免签支付源码+监控APP/实测成功
  14. Could not transfer artifact org.springframework.boot:spring-boot-starter-parent:pom:2.3.0.RELEAS错误解决
  15. 使用PhotoShop制作公章
  16. 关于jmeter运行提示没有权限 报错
  17. forward和redirect的区别是什么?
  18. 从零开始学C++11新标准知识(内含大厂面试题100道)第二期
  19. Linux收音机软件,在Linux终端听收音机
  20. java版b2b2c社交电商分布式微服务-Spring Cloud Netflix

热门文章

  1. linux下截图软件,Flameshot - Linux下功能强大的屏幕截图软件
  2. 自建网站开通SSL协议
  3. SameSite Cookie问题处理解决方案(谷歌Chome浏览器出现Whitelabel Error Page或者不停请求现象解决)
  4. C++ + ubuntu 调用boost 的一个问题
  5. arcgis将直线等分_如何快速定数等分一条线段?
  6. Vue项目中的静态资源引入
  7. Beta阶段站立会议-01
  8. XPO学习(6)----实现一个简单的留言薄(ASP.NET)
  9. oracle卸载ksh,oracle与ksh(Korn Shell) | 学步园
  10. 实例三十六:精确除法计算(*)