推荐自用 Javascript 缩图函数 (onDOMLoaded)……


Posted in Javascript onOctober 23, 2007

070520:Norman 君给出了 Dean Edwards 等关于 onDOMLoaded 事件的跨浏览器解决方案……
其实 onDOMLoaded 是 DOM 被载入(图片尚未载入)状态下的一个“不存在的”事件……
由于不同浏览器的支持度不同……
所以需要进行 Hack ……
所幸 Dean 和其他一些朋友反复研究后给出了解决方案……
在此表示感谢……
对于缩图函式本身的改进就是合并了上个版本的两个不同模式(快速和平缓)……
所谓快速模式是用了 while 循环……
速度快但是容易造成假死……
所谓平缓模式则用 setInterval 函式来解决上述问题……
可惜 setInterval 有最短周期限制……
所以速度比较慢……
从快速到平缓模式的切换临界值我设置为 500 ……
也即当一个页面的图片达到 500 时便启用平缓模式来缩图……
大伙儿可以根据自己需求更改……
具体请看 resizeImgs 函式的第二行……

070516:感谢 Norman 君在提升代码性能上的建议……
将遍历所有元素更改为遍历图像数组……
至于 Norman 所提议的在图像读取之前即进行缩图的功能……
未能实现……
一来是因为 Firefox 并不支持 onreadystatechange 事件(只有 onload ?)……
二来则在测试中发现 IE 下在 interactive 状态下调整图像大小也需要刷新以后才能执行……
也就是说都得等到页面加载完毕(或者加载一次)后才能进行操作……
恕鄙人才疏学浅……
如有解决方案望留言教授……

原理呢……
就是遍历图像数组……
如果定义了 resize 属性就进行缩图……
当 resize 的值为数字(而且小于原图宽度)就缩小到该数字宽度……
当 resize 为其它值则缩小到预设宽度……
至于为什么要清除 height 属性……
答曰:为了保持宽、高之比……
以上……

由于代码过长……
暂不贴出……
使用方法请参看 Demo ……
https://3water.com/test/resizeIMGs_1.2/index.html
本地下载

Javascript 相关文章推荐
如何实现iframe(嵌入式帧)的自适应高度
Jul 26 Javascript
Jquery Ajax 学习实例2 向页面发出请求 返回JSon格式数据
Mar 15 Javascript
jquery select下拉框操作的一些说明
Apr 02 Javascript
JavaScript 语言基础知识点总结(思维导图)
Nov 10 Javascript
推荐 21 款优秀的高性能 Node.js 开发框架
Aug 18 Javascript
网页禁用右键菜单和鼠标拖动选择方法小结
Feb 25 Javascript
JavaScript常用本地对象小结
Mar 28 Javascript
jQuery绑定事件的四种方式介绍
Oct 31 Javascript
webpack构建vue项目的详细教程(配置篇)
Jul 17 Javascript
vue中本地静态图片路径写法
Mar 06 Javascript
Async/Await替代Promise的6个理由
Jun 15 Javascript
避坑之 JavaScript 中的toFixed()和正则表达式
Apr 19 Javascript
非常漂亮的JS代码经典广告
Oct 21 #Javascript
国外Lightbox v2.03.3 最新版 下载
Oct 17 #Javascript
javascript[js]获取url参数的代码
Oct 17 #Javascript
javascript中的有名函数和无名函数
Oct 17 #Javascript
JS网络游戏-(模拟城市webgame)提供的一些例子下载
Oct 14 #Javascript
表单填写时用回车代替TAB的实现方法
Oct 09 #Javascript
关于 byval 与 byref 的区别分析总结
Oct 08 #Javascript
You might like
PHP+MySQL5.0中文乱码解决方法
2006/11/20 PHP
学习php笔记 字符串处理
2010/10/19 PHP
php中autoload的用法总结
2013/11/08 PHP
PHP读MYSQL中文乱码的快速解决方法
2016/10/01 PHP
php实现和c#一致的DES加密解密实例
2017/07/24 PHP
PHP实现按之字形顺序打印二叉树的方法
2018/01/16 PHP
PHP设计模式之模板模式定义与用法详解
2018/12/20 PHP
JavaScript插入动态样式实现代码
2012/02/22 Javascript
Javascript页面添加到收藏夹的简单方法
2013/08/07 Javascript
上传图片预览JS脚本 Input file图片预览的实现示例
2014/10/23 Javascript
jQuery搜索同辈元素方法
2015/02/10 Javascript
浅谈MVC+EF easyui dataGrid 动态加载分页表格
2016/11/10 Javascript
inner join 内联与left join 左联的实例代码
2017/09/18 Javascript
jQuery实现切换隐藏与显示同时切换图标功能
2017/10/29 jQuery
JavaScript 中的12种循环遍历方法【总结】
2018/05/31 Javascript
利用Decorator如何控制Koa路由详解
2018/06/26 Javascript
vue修改对象的属性值后页面不重新渲染的实例
2018/08/09 Javascript
详解Vue-axios 设置请求头问题
2018/12/06 Javascript
layUI实现前端分页和后端分页
2019/07/27 Javascript
如何利用javascript接收json信息并进行处理
2020/08/06 Javascript
[52:12]FNATIC vs Infamous 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/19 DOTA
Python简单计算文件夹大小的方法
2015/07/14 Python
Python批量提取PDF文件中文本的脚本
2018/03/14 Python
transform python环境快速配置方法
2018/09/27 Python
Tesserocr库的正确安装方式
2018/10/19 Python
关于python导入模块import与常见的模块详解
2019/08/28 Python
如何关掉pycharm中的python console(图解)
2019/10/31 Python
python实现门限回归方式
2020/02/29 Python
python实现飞船游戏的纵向移动
2020/04/24 Python
Python爬虫工具requests-html使用解析
2020/04/29 Python
用Python实现职工信息管理系统
2020/12/30 Python
CSS3制作轮播图的一种方法
2019/11/11 HTML / CSS
椰子猫砂:CatSpot
2018/08/27 全球购物
STRATHBERRY苏贝瑞包包官网:西班牙高级工匠手工打造
2020/11/10 全球购物
矿泉水广告词
2014/03/20 职场文书
2014国庆节商场促销活动策划方案
2014/09/16 职场文书