您好,欢迎访问一九零五行业门户网

基于JavaScript实现移动端点击图片查看大图点击大图隐藏_javascript技巧

一、需求
点击图片查看大图,再点大图隐藏。多用于移动端,因为移动端屏幕小,可能需要查看大图。
二、代码
jquery点击图片查看大图by starof

三、技巧
因为移动端无法添加热点,最终一个解决方法是使用四个a标签定位到左上角,右上角,左下角,右下角四个区域。
...css.topleft,.topright,.bottomleft,.bottomright{ width:50%; height:50%; position:absolute;}.topleft{ /*background-color:red;*/ top:0; left:0;}.topright{ /*background-color:green;*/ top:0; right:0;}.bottomleft{ /*background-color:blue;*/ bottom:0; left:0;}.bottomright{ /*background-color:yellow;*/ bottom:0; right:0;}
ps:手机网站移动端图片实现延迟加载
由于国内的电信网络性价比的限制,和手机处理能力的差异,在设计一个无线应用的时候,
为用户节省流量是一个非常重要的考虑因素。可以说每一个字节都应该为客户端节省。
节约流量可以从以下几个方面关注:
一、使用缓存 比如 利用浏览器本地存储 前面已经讨论过
二、延迟加载代码 (触底检测,通过接口获取数据)
三、资源的延迟加载,图片出现在可视区域再加载,(不考虑自动播放的情况下)音频视频按用户点击加载。
今天简单说一下图片延迟加载的实现方式。
例子基于jquery 和 jquery mobile
原理:用户滑动屏幕,屏幕滚动结束(用jquery 提供的 window scrollstop 事件合适 ) 检测出现在viewport中的图片。
替换图片的 真正 src 属性即可。
技巧:滚动结束之后不要立即检测加载,设置一秒延时,也许用户会立即开始下一次滚屏,基于现在的网络环境,1秒的延时可以说明用户真正想查看这些内容。用微信的朋友可以仔细体验一下这一点。
由于有时钟的控制,当用户频繁快速翻动屏幕,不会发大量请求。
主要代码:
var refreshtimer = null, mebook = mebook || {};/**滚动结束 屏幕静止一秒后检测哪些图片出现在viewport中*和pc端不同 由于无线速度限制 和手机运算能力的差异 1秒钟的延迟对手机端的用户来说可以忍受*/$(window).on('scrollstop', function () { if (refreshtimer) { cleartimeout(refreshtimer); refreshtimer = null; } refreshtimer = settimeout(refreshall, 1e3);});$.belowthefold = function (element) { var fold = $(window).height() + $(window).scrolltop(); return fold = $(element).offset().top + $(element).height();};/**判断元素是否出现在viewport中 依赖于上两个扩展方法 */$.inviewport = function (element) { return !$.belowthefold(element) && !$.abovethetop(element)};mebook.getinviewportlist = function () { var list = $('#booklist li'), ret = []; list.each(function (i) { var li = list.eq(i); if ($.inviewport(li)) { mebook.loadimg(li); } });};mebook.loadimg = function (li) { if (li.find('img[_src]').length) { var img = li.find('img[_src]'), src = img.attr('_src'); img.attr('src', src).load(function () { img.removeattr('_src'); }); }};
其它类似信息

推荐信息