基于JavaScript實(shí)現(xiàn)移動(dòng)端點(diǎn)擊圖片查看大圖點(diǎn)擊大圖隱藏
一、需求
點(diǎn)擊圖片查看大圖,再點(diǎn)大圖隱藏。多用于移動(dòng)端,因?yàn)橐苿?dòng)端屏幕小,可能需要查看大圖。
二、代碼
<!DOCTYPE html> <html> <meta charset="utf-8"/> <head runat="server"> <title>JQuery點(diǎn)擊圖片查看大圖by starof</title> <style type="text/css"> .exampleImg { height:100px; cursor:pointer;} </style> <script src="http://code.jquery.com/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> </head> <body> <div> <!--第一種寫(xiě)法--> <img class="exampleImg" src="images/03.jpg" id="imgTest"/> <!--第二種寫(xiě)法--> <img class="exampleImg" src="images/p1_nav2.png" onClick="$(this).ImgZoomIn();"/> </div> </body> </html>
三、技巧
因?yàn)橐苿?dòng)端無(wú)法添加熱點(diǎn),最終一個(gè)解決方法是使用四個(gè)a標(biāo)簽定位到左上角,右上角,左下角,右下角四個(gè)區(qū)域。
<dl> <dd style="display:block;"> <img src="images/four-duche.jpg" onClick="$(this).ImgZoomIn();"> <a href="javascript:;" src="images/11.jpg" class="topleft" onClick="$(this).ImgZoomIn();"></a> <a href="javascript:;" src="images/12.jpg" class="topright" onClick="$(this).ImgZoomIn();"></a> <a href="javascript:;" src="images/13.jpg" class="bottomleft" onClick="$(this).ImgZoomIn();"></a> <a href="javascript:;" src="images/14.jpg" class="bottomright" onClick="$(this).ImgZoomIn();"></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:手機(jī)網(wǎng)站移動(dòng)端圖片實(shí)現(xiàn)延遲加載
由于國(guó)內(nèi)的電信網(wǎng)絡(luò)性價(jià)比的限制,和手機(jī)處理能力的差異,在設(shè)計(jì)一個(gè)無(wú)線應(yīng)用的時(shí)候,
為用戶節(jié)省流量是一個(gè)非常重要的考慮因素??梢哉f(shuō)每一個(gè)字節(jié)都應(yīng)該為客戶端節(jié)省。
節(jié)約流量可以從以下幾個(gè)方面關(guān)注:
一、使用緩存 比如 利用瀏覽器本地存儲(chǔ) 前面已經(jīng)討論過(guò)
二、延遲加載代碼 (觸底檢測(cè),通過(guò)接口獲取數(shù)據(jù))
三、資源的延遲加載,圖片出現(xiàn)在可視區(qū)域再加載,(不考慮自動(dòng)播放的情況下)音頻視頻按用戶點(diǎn)擊加載。
今天簡(jiǎn)單說(shuō)一下圖片延遲加載的實(shí)現(xiàn)方式。
例子基于jQuery 和 jQuery mobile
原理:用戶滑動(dòng)屏幕,屏幕滾動(dòng)結(jié)束(用jQuery 提供的 window scrollstop 事件合適 ) 檢測(cè)出現(xiàn)在viewport中的圖片。
替換圖片的 真正 src 屬性即可。
技巧:滾動(dòng)結(jié)束之后不要立即檢測(cè)加載,設(shè)置一秒延時(shí),也許用戶會(huì)立即開(kāi)始下一次滾屏,基于現(xiàn)在的網(wǎng)絡(luò)環(huán)境,1秒的延時(shí)可以說(shuō)明用戶真正想查看這些內(nèi)容。用微信的朋友可以仔細(xì)體驗(yàn)一下這一點(diǎn)。
由于有時(shí)鐘的控制,當(dāng)用戶頻繁快速翻動(dòng)屏幕,不會(huì)發(fā)大量請(qǐng)求。
主要代碼:
var refreshTimer = null, mebook = mebook || {}; /* *滾動(dòng)結(jié)束 屏幕靜止一秒后檢測(cè)哪些圖片出現(xiàn)在viewport中 *和PC端不同 由于無(wú)線速度限制 和手機(jī)運(yùn)算能力的差異 1秒鐘的延遲對(duì)手機(jī)端的用戶來(lái)說(shuō)可以忍受 */ $(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(); }; /* *判斷元素是否出現(xiàn)在viewport中 依賴于上兩個(gè)擴(kuò)展方法 */ $.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'); }); } };
- viewer.js一個(gè)強(qiáng)大的基于jQuery的圖像查看插件(支持旋轉(zhuǎn)、縮放)
- JS簡(jiǎn)單實(shí)現(xiàn)查看文檔創(chuàng)建日期、修改日期和文檔大小的方法示例
- js canvas實(shí)現(xiàn)放大鏡查看圖片功能
- JavaScript編寫(xiě)點(diǎn)擊查看大圖的頁(yè)面半透明遮罩層效果實(shí)例
- js寫(xiě)的方法實(shí)現(xiàn)上傳圖片之后查看大圖
- javascript基礎(chǔ)知識(shí)大全 便于大家學(xué)習(xí),也便于我自己查看
- JS網(wǎng)頁(yè)圖片查看器(兼容IE、FF)可控制圖片放大縮小移動(dòng)
- Javascript查看大圖功能代碼實(shí)現(xiàn)
相關(guān)文章
JS插件clipboard.js實(shí)現(xiàn)一鍵復(fù)制粘貼功能
這篇文章主要介紹了JS插件clipboard.js實(shí)現(xiàn)一鍵復(fù)制粘貼功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08html判斷當(dāng)前頁(yè)面是否在iframe中的實(shí)例
下面小編就為大家?guī)?lái)一篇html判斷當(dāng)前頁(yè)面是否在iframe中的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11js給對(duì)象動(dòng)態(tài)添加、設(shè)置、刪除屬性名與屬性值實(shí)例代碼
由于項(xiàng)目需要常常會(huì)遇到為某一個(gè)對(duì)象動(dòng)態(tài)添加屬性的情況,下面這篇文章主要給大家介紹了關(guān)于js給對(duì)象動(dòng)態(tài)添加、設(shè)置、刪除屬性名與屬性值的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11在IE下獲取object(ActiveX)的Param的代碼
在IE下,獲取Param的時(shí)候有個(gè)詭異現(xiàn)象(不知道算不算bug)。2009-09-09javascript 回到頂部效果的實(shí)現(xiàn)代碼
本篇文章主要是對(duì)javascript 回到頂部效果的實(shí)現(xiàn)代碼進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02javascript模板方法模式和職責(zé)鏈模式實(shí)例分析
這篇文章主要介紹了javascript模板方法模式和職責(zé)鏈模式,結(jié)合實(shí)例形式較為詳細(xì)的分析了模板方法模式和職責(zé)鏈模式基本原理、實(shí)現(xiàn)方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2023-07-07javascript 操作Word和Excel的實(shí)現(xiàn)代碼
javascript 操作Word和Excel的實(shí)現(xiàn)代碼, 需要的朋友可以參考下。2009-10-10JS實(shí)現(xiàn)圖片上傳多次上傳同一張不生效的處理方法
這篇文章主要介紹了JS實(shí)現(xiàn)圖片上傳多次上傳同一張不生效的處理方法,處理方法也很簡(jiǎn)單,只要在刪除方法里置空input,具體實(shí)例代碼大家參考下本文2018-08-08javaScript實(shí)現(xiàn)復(fù)選框全選反選事件詳解
這篇文章主要為大家詳細(xì)介紹了javaScript實(shí)現(xiàn)復(fù)選框全選反選事件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09