亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > 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:手機網站移動端圖片實現延遲加載

由于國內的電信網絡性價比的限制,和手機處理能力的差異,在設計一個無線應用的時候,

為用戶節省流量是一個非常重要的考慮因素??梢哉f每一個字節都應該為客戶端節省。

節約流量可以從以下幾個方面關注:

一、使用緩存 比如 利用瀏覽器本地存儲 前面已經討論過

二、延遲加載代碼 (觸底檢測,通過接口獲取數據)

三、資源的延遲加載,圖片出現在可視區域再加載,(不考慮自動播放的情況下)音頻視頻按用戶點擊加載。

今天簡單說一下圖片延遲加載的實現方式。

例子基于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. }; 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美与欧洲交xxxx免费观看| 日韩一区在线视频| 免费97视频在线精品国自产拍| 欧美黑人xxx| 欧美亚洲成人网| 亚洲最大的av网站| 这里精品视频免费| 久久精品美女视频网站| 亚洲男人天堂九九视频| 一区国产精品视频| 亚洲片在线观看| 中文日韩在线观看| 第一福利永久视频精品| 欧美日韩在线看| 成人黄色片在线| 日韩免费观看网站| 欧美激情在线播放| 精品国产乱码久久久久久婷婷| 欧美日韩国产va另类| 欧美一级淫片aaaaaaa视频| 亚洲成人精品视频在线观看| 国产欧美一区二区三区久久人妖| 亚洲xxxxx电影| 精品国产电影一区| 成人免费看吃奶视频网站| 黄网动漫久久久| 日韩精品福利网站| 色综合久久88色综合天天看泰| 成人激情视频在线播放| 久久精品国产电影| 51ⅴ精品国产91久久久久久| 亚洲天堂av女优| 久久不射电影网| 美女av一区二区| 亚洲网站在线观看| 日韩中文字幕网址| 久久国产精品电影| 亚洲欧美一区二区三区四区| 91人人爽人人爽人人精88v| 久久久久国产视频| 中文字幕亚洲综合| 精品久久久免费| 中文字幕自拍vr一区二区三区| 欧美日本中文字幕| 亚洲性av网站| 欧洲亚洲女同hd| 亚洲精品视频在线播放| 日韩在线视频线视频免费网站| 成年人精品视频| 97超级碰碰碰| 国产精品综合久久久| 欧美亚洲在线视频| 亚洲综合在线中文字幕| 98视频在线噜噜噜国产| 中文字幕视频一区二区在线有码| 亚洲第一福利视频| 欧美激情乱人伦一区| 国产精品7m视频| 欧美黄色免费网站| 亚洲人成啪啪网站| 亚洲精品小视频| 色综合色综合久久综合频道88| 久久久久久中文| 97视频在线观看免费| 中文字幕在线国产精品| 国产久一一精品| 国产精品视频自在线| 国产精品久久国产精品99gif| 欧美精品手机在线| 搡老女人一区二区三区视频tv| 97精品一区二区视频在线观看| 91精品国产91久久久久久久久| 国产精品电影观看| 亚洲中国色老太| 国产日韩在线免费| 亚洲最大的成人网| 麻豆国产va免费精品高清在线| 亚洲aⅴ男人的天堂在线观看| 日韩电影中文 亚洲精品乱码| 国产精品亚洲激情| 日韩av中文字幕在线播放| 国产精品一区二区在线| 国产精品电影久久久久电影网| 欧美大肥婆大肥bbbbb| 欧美激情亚洲国产| 欧美日韩成人网| 欧美亚洲另类视频| 久久久精品在线观看| 久久久电影免费观看完整版| 久久色免费在线视频| 亚洲欧美中文日韩在线v日本| 欧美电影免费播放| 成人午夜一级二级三级| 一本色道久久88综合亚洲精品ⅰ| 国产亚洲欧美另类中文| 久久成年人视频| 欧美在线播放视频| 亚洲人成欧美中文字幕| 91亚洲一区精品| 91国内免费在线视频| 亚洲国产精品久久久久秋霞蜜臀| 精品久久久久久久中文字幕| 91情侣偷在线精品国产| 精品福利免费观看| 久久久久久久久国产| 亚洲国产精久久久久久| 日韩精品黄色网| 欧美另类69精品久久久久9999| 亚洲成人精品久久| 久久久91精品国产一区不卡| 一区二区亚洲精品国产| 91色琪琪电影亚洲精品久久| 久久精品电影网站| 亚洲xxx大片| 热久久免费国产视频| 亚洲欧美一区二区精品久久久| 97视频人免费观看| 中文字幕亚洲无线码a| 欧美黑人一区二区三区| 久久免费视频这里只有精品| 欧美午夜视频一区二区| 久久久久久久久国产精品| 日韩电视剧在线观看免费网站| 2018中文字幕一区二区三区| 海角国产乱辈乱精品视频| 国产性猛交xxxx免费看久久| 亚洲精品资源在线| 久久久久北条麻妃免费看| 国产成人高清激情视频在线观看| 亚洲欧美日韩国产中文| 久久综合88中文色鬼| 日韩国产中文字幕| 国产精品盗摄久久久| 久久久久久999| 国产综合在线看| 欧美日韩国产精品| 国产成人精品久久久| 国产激情综合五月久久| 国产偷国产偷亚洲清高网站| 欧美日本高清一区| 亚洲男人的天堂在线| 日韩国产在线播放| 日韩电影免费观看在线观看| 国产一区二区动漫| 欧美黑人巨大精品一区二区| 91久久精品国产91性色| 国产精品美女www爽爽爽视频| 精品人伦一区二区三区蜜桃网站| 日韩精品在线影院| 午夜免费久久久久| 久久国产精品电影| 国产有码在线一区二区视频| 亚洲欧美日本精品| 精品久久国产精品| 国产91精品久久久久久久| 伊人久久男人天堂| 在线观看欧美日韩| 久久久久中文字幕2018| 欧美日韩午夜剧场| 久久久久久久久久久av| 国产精品毛片a∨一区二区三区|国| 九九九热精品免费视频观看网站| 国产欧美日韩丝袜精品一区| 精品欧美激情精品一区|