100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > 基于JavaScript实现移动端点击图片查看大图点击大图隐藏

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

时间:2020-07-20 15:19:27

相关推荐

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

今天找到了一个我用了很好的方法,点击缩略图,放大居中展示,且参数可调,亲测可靠。

代码使用意见,将下面的代码放到本地测试效果,可以用一张自己的照片,点击会放大,再次点击还原。

一、需求

点击图片查看大图,再点大图隐藏。多用于移动端,因为移动端屏幕小,可能需要查看大图。

二、代码

<title>JQuery点击图片查看大图by starof</title><style type="text/css">.exampleImg { height:100px; cursor:pointer;}</style><script src="/jquery-latest.js"></script><script type="text/javascript">//alert($);// (function (window, undefined) {// var MyJQuery = function () {// window.MyjQuery = window.$ = jQuery; window.$ = MyJQuery;// };// })(window);// alert($);$.fn.ImgZoomIn = function () {bgstr = '<div id="ImgZoomInBG" style=" background:#000000; filter:Alpha(Opacity=70); opacity:0.7; position:fixed; left:0; top:0; z-index:10000; width:100%; height:100%; display:none;"><iframe src="about:blank" frameborder="5px" scrolling="yes" style="width:100%; height:100%;"></iframe></div>';//alert($(this).attr('src'));imgstr = '<img id="ImgZoomInImage" src="' + $(this).attr('src')+'" onclick=$(\'#ImgZoomInImage\').hide();$(\'#ImgZoomInBG\').hide(); style="cursor:pointer; display:none; position:absolute; z-index:10001;" />';if ($('#ImgZoomInBG').length < 1) {$('body').append(bgstr);}if ($('#ImgZoomInImage').length < 1) {$('body').append(imgstr);}else {$('#ImgZoomInImage').attr('src', $(this).attr('src'));}//alert($(window).scrollLeft());//alert( $(window).scrollTop());$('#ImgZoomInImage').css('left', $(window).scrollLeft() + ($(window).width() - $('#ImgZoomInImage').width()) / 2);$('#ImgZoomInImage').css('top', $(window).scrollTop() + ($(window).height() - $('#ImgZoomInImage').height()) / 2);$('#ImgZoomInBG').show();$('#ImgZoomInImage').show();};$(document).ready(function () {$("#imgTest").bind("click", function () {$(this).ImgZoomIn();});});</script><div><!--第一种写法--><img class="exampleImg" id="imgTest" src="images/03.jpg"><!--第二种写法--><img class="exampleImg" onclick="$(this).ImgZoomIn();" src="images/p1_nav2.png"></div>

三、技巧

因为移动端无法添加热点,最终一个解决方法是使用四个a标签定位到左上角,右上角,左下角,右下角四个区域

<dl><dd style="display: block;"><img onclick="$(this).ImgZoomIn();" src="images/four-duche.jpg"><a class="topleft" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/11.jpg"></a><a class="topright" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/12.jpg"></a><a class="bottomleft" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/13.jpg"></a><a class="bottomright" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/14.jpg"></a></dd>...</dl>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;};$.abovethetop = function (element) {var top = $(window).scrollTop();return top >= $(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');});}};

全文参考:/js-tutorial-4421.html

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。