首页 > 语言 > JavaScript > 正文

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

2024-05-06 16:24:55
字体:
来源:转载
供稿:网友

最近接了个项目,项目需求是这样的,当点击图片查看图片,再次点击大图被隐藏,在移动端用的比较多,因为移动端屏幕小,需要查看大图。具体代码实现过程本文给大家介绍,需要的朋友可以参考下

一、需求

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

二、代码

 

 
  1. <!DOCTYPE html> 
  2. <html> 
  3. <meta charset="utf-8"/> 
  4. <head runat="server"
  5. <title>JQuery点击图片查看大图by starof</title> 
  6. <style type="text/css"
  7. .exampleImg { height:100px; cursor:pointer;} 
  8. </style> 
  9. <script src="http://code.jquery.com/jquery-latest.js"></script> 
  10. <script type="text/javascript"
  11. //alert($); 
  12. // (function (window, undefined) { 
  13. // var MyJQuery = function () { 
  14. // window.MyjQuery = window.$ = jQuery; window.$ = MyJQuery; 
  15. // }; 
  16. // })(window); 
  17. // alert($); 
  18. $.fn.ImgZoomIn = function () { 
  19. 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>'
  20. //alert($(this).attr('src')); 
  21. imgstr = '<img id="ImgZoomInImage" src="' + $(this).attr('src')+'" onclick=$(/'#ImgZoomInImage/').hide();$(/'#ImgZoomInBG/').hide(); style="cursor:pointer; display:none; position:absolute; z-index:10001;" />'
  22. if ($('#ImgZoomInBG').length < 1) { 
  23. $('body').append(bgstr); 
  24. if ($('#ImgZoomInImage').length < 1) { 
  25. $('body').append(imgstr); 
  26. else { 
  27. $('#ImgZoomInImage').attr('src', $(this).attr('src')); 
  28. //alert($(window).scrollLeft()); 
  29. //alert( $(window).scrollTop()); 
  30. $('#ImgZoomInImage').css('left', $(window).scrollLeft() + ($(window).width() - $('#ImgZoomInImage').width()) / 2); 
  31. $('#ImgZoomInImage').css('top', $(window).scrollTop() + ($(window).height() - $('#ImgZoomInImage').height()) / 2); 
  32. $('#ImgZoomInBG').show(); 
  33. $('#ImgZoomInImage').show(); 
  34. }; 
  35. $(document).ready(function () { 
  36. $("#imgTest").bind("click"function () { 
  37. $(this).ImgZoomIn(); 
  38. }); 
  39. }); 
  40. </script> 
  41. </head> 
  42. <body> 
  43. <div> 
  44. <!--第一种写法--> 
  45. <img class="exampleImg" src="images/03.jpg" id="imgTest"/> 
  46. <!--第二种写法--> 
  47. <img class="exampleImg" src="images/p1_nav2.png" onClick="$(this).ImgZoomIn();"/> 
  48. </div> 
  49. </body> 
  50. </html> 

三、技巧

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

 

 
  1. <dl> 
  2. <dd style="display:block;"
  3. <img src="images/four-duche.jpg" onClick="$(this).ImgZoomIn();"
  4. <a href="javascript:;" src="images/11.jpg" class="topleft" onClick="$(this).ImgZoomIn();"></a> 
  5. <a href="javascript:;" src="images/12.jpg" class="topright" onClick="$(this).ImgZoomIn();"></a> 
  6. <a href="javascript:;" src="images/13.jpg" class="bottomleft" onClick="$(this).ImgZoomIn();"></a> 
  7. <a href="javascript:;" src="images/14.jpg" class="bottomright" onClick="$(this).ImgZoomIn();"></a> 
  8. </dd> 
  9. ... 
  10. </dl> 
  11. css 
  12. .topleft,.topright,.bottomleft,.bottomright{ 
  13. width:50%; 
  14. height:50%; 
  15. position:absolute; 
  16. .topleft{ 
  17. /*background-color:red;*/ 
  18. top:0; 
  19. left:0; 
  20. .topright{ 
  21. /*background-color:green;*/ 
  22. top:0; 
  23. right:0; 
  24. .bottomleft{ 
  25. /*background-color:blue;*/ 
  26. bottom:0; 
  27. left:0; 
  28. .bottomright{ 
  29. /*background-color:yellow;*/ 
  30. bottom:0; 
  31. right:0; 

PS:手机网站移动端图片实现延迟加载

由于国内的电信网络性价比的限制,和手机处理能力的差异,在设计一个无线应用的时候,

为用户节省流量是一个非常重要的考虑因素。可以说每一个字节都应该为客户端节省。

节约流量可以从以下几个方面关注:

一、使用缓存 比如 利用浏览器本地存储 前面已经讨论过

二、延迟加载代码 (触底检测,通过接口获取数据)

三、资源的延迟加载,图片出现在可视区域再加载,(不考虑自动播放的情况下)音频视频按用户点击加载。

今天简单说一下图片延迟加载的实现方式。

例子基于jQuery 和 jQuery mobile

原理:用户滑动屏幕,屏幕滚动结束(用jQuery 提供的 window scrollstop 事件合适 ) 检测出现在viewport中的图片。

替换图片的 真正 src 属性即可。

技巧:滚动结束之后不要立即检测加载,设置一秒延时,也许用户会立即开始下一次滚屏,基于现在的网络环境,1秒的延时可以说明用户真正想查看这些内容。用微信的朋友可以仔细体验一下这一点。

由于有时钟的控制,当用户频繁快速翻动屏幕,不会发大量请求。

主要代码:

 

 
  1. var refreshTimer = null
  2. mebook = mebook || {}; 
  3. /* 
  4. *滚动结束 屏幕静止一秒后检测哪些图片出现在viewport中 
  5. *和PC端不同 由于无线速度限制 和手机运算能力的差异 1秒钟的延迟对手机端的用户来说可以忍受 
  6. */ 
  7. $(window).on('scrollstop'function () { 
  8. if (refreshTimer) { 
  9. clearTimeout(refreshTimer); 
  10. refreshTimer = null
  11. refreshTimer = setTimeout(refreshAll, 1e3); 
  12. }); 
  13. $.belowthefold = function (element) { 
  14. var fold = $(window).height() + $(window).scrollTop(); 
  15. return fold <= $(element).offset().top; 
  16. }; 
  17. $.abovethetop = function (element) { 
  18. var top = $(window).scrollTop(); 
  19. return top >= $(element).offset().top + $(element).height(); 
  20. }; 
  21. /* 
  22. *判断元素是否出现在viewport中 依赖于上两个扩展方法  
  23. */ 
  24. $.inViewport = function (element) { 
  25. return !$.belowthefold(element) && !$.abovethetop(element) 
  26. }; 
  27. mebook.getInViewportList = function () { 
  28. var list = $('#bookList li'), 
  29. ret = []; 
  30. list.each(function (i) { 
  31. var li = list.eq(i); 
  32. if ($.inViewport(li)) { 
  33. mebook.loadImg(li); 
  34. }); 
  35. }; 
  36. mebook.loadImg = function (li) { 
  37. if (li.find('img[_src]').length) { 
  38. var img = li.find('img[_src]'), 
  39. src = img.attr('_src'); 
  40. img.attr('src', src).load(function () { 
  41. img.removeAttr('_src'); 
  42. }); 
  43. }; 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选