推荐自用 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 相关文章推荐
javascript 动态数据下的锚点错位问题解决方法
Dec 24 Javascript
JQuery 常用操作代码
Mar 14 Javascript
JS实现模拟百度搜索“2012世界末日”网页地震撕裂效果代码
Oct 31 Javascript
js实现分割上传大文件
Mar 09 Javascript
JS扩展类,克隆对象与混合类实例分析
Nov 26 Javascript
解析JavaScript模仿块级作用域
Dec 29 Javascript
javascript常用经典算法详解
Jan 11 Javascript
jQuery插件HighCharts实现的2D回归直线散点效果示例【附demo源码下载】
Mar 09 Javascript
JS+CSS实现下拉刷新/上拉加载插件
Mar 31 Javascript
weebox弹出窗口不居中显示的解决方法
Nov 27 Javascript
解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题
Aug 20 Javascript
Vue ElementUI实现:限制输入框只能输入正整数的问题
Jul 31 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
php5中类的学习
2008/03/28 PHP
PHP实现的一致性哈希算法完整实例
2015/11/14 PHP
php实现将HTML页面转换成word并且保存的方法
2016/10/14 PHP
Yii2实现UploadedFile上传文件示例
2017/02/15 PHP
Javascript UrlDecode函数代码
2010/01/09 Javascript
Javascript学习笔记4 Eval函数
2010/01/11 Javascript
原生js实现改变随意改变div属性style的名称和值的结果
2013/09/26 Javascript
jquery 操作iframe的几种方法总结
2013/12/13 Javascript
javascript函数重载解决方案分享
2014/02/19 Javascript
超炫的jquery仿flash导航栏特效
2014/11/11 Javascript
jQuery代码实现图片墙自动+手动淡入淡出切换效果
2016/05/09 Javascript
Node.js读取文件内容示例
2017/03/07 Javascript
vue实现app页面切换动画效果实例
2017/05/23 Javascript
深入浅析Vue不同场景下组件间的数据交流
2017/08/15 Javascript
web前端vue之CSS过渡效果示例
2018/01/10 Javascript
vue-cli3 karma单元测试的实现
2019/01/18 Javascript
Vue实现导航栏的显示开关控制
2019/11/01 Javascript
在vue-cli创建的项目中使用sass操作
2020/08/10 Javascript
echarts浮动显示单位的实现方法示例
2020/12/04 Javascript
Python笔记(叁)继续学习
2012/10/24 Python
详解使用 pyenv 管理多个版本 python 环境
2017/10/19 Python
python对绑定事件的鼠标、按键的判断实例
2019/07/17 Python
django xadmin中form_layout添加字段显示方式
2020/03/30 Python
Python面向对象特殊属性及方法解析
2020/09/16 Python
python判断变量是否为列表的方法
2020/09/17 Python
详解pycharm的python包opencv(cv2)无代码提示问题的解决
2021/01/29 Python
html5实现多文件的上传示例代码
2014/02/13 HTML / CSS
英文简历中的自我评价
2013/10/06 职场文书
市场营销专业毕业生自荐信
2013/11/02 职场文书
基层干部十八大感言
2014/01/19 职场文书
《唯一的听众》教学反思
2014/02/20 职场文书
中学清明节活动总结
2014/07/04 职场文书
2014保险公司个人工作总结
2014/12/09 职场文书
北京天坛导游词
2015/02/12 职场文书
心得体会该怎么写呢?
2019/06/27 职场文书
Mysql中有关Datetime和Timestamp的使用总结
2021/12/06 MySQL