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

首頁 > 編程 > JavaScript > 正文

如何讓你的Lightbox支持滾輪縮放及Base64圖片

2019-11-20 13:49:23
字體:
來源:轉載
供稿:網友

在做文章類型的web頁時,經常會遇到要點開看大圖的需求,LightBox2則是在眾多產品中比較優秀的一款Jquery插件。配置就不細說了,今天我主要要分享的是:如何在點開大圖后,可以通過鼠標滾輪來縮放圖片,

1、修改Lightbox源碼使支持滾輪縮放

    支持鼠標滾輪主要就是把彈出后的框整個綁定上mousewheel事件,打開lightbox.js,找到Lightbox.prototype.build = function() {...}這一段,可以在這里(lightbox初始化的時候)把想要的滾輪事件綁定上去,比如在函數的末尾添加如下代碼:

復制代碼 代碼如下:

       // 圖片滾輪縮放
       this.img = this.$container.find('.lb-image');
       this.label = this.$lightbox.find('.lb-dataContainer');
       $([this.$overlay[0],this.$lightbox[0]]).bind("mousewheel", function(e){
           var flag= e.originalEvent.wheelDelta < 0;
           var imgH = self.img.height();
           var imgW = self.img.width();
           var nw = Math.round(20*imgW/imgH);
           var ctH = self.$outerContainer.height();
           var ctW = self.$outerContainer.width();
           var layH = self.$overlay.height()-20;
           var layW = self.$overlay.width()-20;
           // 向下
           if(flag && imgH>20 && imgW>20) {
               self.img.css('height', imgH - 20);
               self.img.css('width', imgW - nw);
               self.$outerContainer.css('height', ctH - 20);
               self.$outerContainer.css('width', ctW - nw);
               if(ctW-nw > 240){
                   self.label.css('width', ctW - nw);
               }
           } else if(!flag && imgH<layH && imgW<layW) {
               self.img.css('height', imgH + 20);
               self.img.css('width', imgW + nw);
               self.$outerContainer.css('height', ctH + 20);
               self.$outerContainer.css('width', ctW + nw);
               self.label.css('width', ctW + nw);
           } 
           e.stopPropagation();
           return false;
       });

    代碼比較好理解,就是給后面背景和前面圖片都添加鼠標滾輪監聽,然后高、寬成比例地縮放(向上滾放大、向下滾縮小),我是設定每次高度變化為20個像素,然后寬度是成比例變化。需要注意的地方,應該是在圖片的最小縮小大小,和圖片放大不能超過屏幕范圍的限制。同時,為了更好的體驗,一定要加上e.stopPropagation(),且返回false,讓瀏覽器不要滾動。

2、修改Lightbox源碼使支持Base64圖片

    這里說起來可能比較麻煩,先來看一下在使用原生Lightbox時的html代碼格式要求:

復制代碼 代碼如下:

<a href="img/image.jpg" data-lightbox="test">Image #1</a>

    這是一個最簡單的彈出圖,當點擊Image #1時,就會彈出一個lightbox顯示img/image.jpg的內容(彈出一個元素<img src="img/image.jpg" />)。
    現在我們來考慮這種情況,如果圖片是以Base64編碼在服務器是存放在數據庫中的?應該就是這樣:

復制代碼 代碼如下:

<a href="data:image/png;base64,iVBORw..." data-lightbox="test">Image #1</a>

    問題來了,href長度在IE下是有限制的,一張大的圖片,不可能放在href字段中,圖片將會被閹割(只顯示上半部分)。
    另外還有一種普遍情況,如果我是先顯示小圖,點擊小圖看大圖,應該就是這樣:

復制代碼 代碼如下:

<a href="data:image/png;base64,iVBORw..." data-lightbox="test">
    <img src="data:image/png;base64,iVBORw..." />
</a>

    好了,這有兩份重復的base64數據,而且都是從服務器端傳過來的,耗時耗帶寬啊。
    所以我按我的需求進行了改造,代碼很簡單,修改Lightbox.prototype.start = function($link) {...} 中的子函數addToAlbum:

復制代碼 代碼如下:

    function addToAlbum($link) {
        self.album.push({
          // link: $link.attr('href'),
          link: $link.children().attr("src"),
          title: $link.attr('data-title') || $link.attr('title')
        });
    }

    注釋掉的部分就是原來的,$link是前面HTML代碼中的a標簽,改過后addToAlbum函數的作用是:在設置彈出圖片的src時,不再從原始的的href中取字符作為彈出img標簽的src,而是直接從a標簽的子元素中找src屬性,由于src屬性的長度無限制,所以它不會存在圖片截斷的問題。 

3、將Lightbox應用到已有的文章

    第2節已經講到了Lightbox使用時HTML有一定的格式,如果已有的文章中的圖片是<img src="img/image.jpg">這樣的,則必須對其進行一層封裝:

復制代碼 代碼如下:

 function initLightbox(){
     var imgs = $(".lightbox-container").find('img');
     $.each(imgs,function(i) {
         var img = $(imgs[i]);
         img.wrap("<a href='' data-lightbox='test' ></a>");       
     });
 }

    其中,“lightbox-container”是文章所在容器的class。initLightbox函數應放置在頁面加載ready時,它會把文章中的所有img標簽都封裝成為lightbox的格式。

本文就寫到這了,第2、3點大家可以看自己的使用場景去使用,lightbox改動的重點在于支持滾輪縮放。

附上修改過的lightbox  http://xiazai.VeVB.COm/201412/yuanma/lightbox(VeVB.COm).rar

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人福利网站在线观看| 国产精品丝袜高跟| 曰本色欧美视频在线| 欧美日韩国产精品一区二区三区四区| 日韩av网址在线观看| 国产精品影院在线观看| 5566成人精品视频免费| 欧美激情奇米色| 亚洲专区在线视频| 一区二区三区国产在线观看| 欧美黑人性猛交| 欧美激情伊人电影| 久久精品电影一区二区| 成人中心免费视频| 色哟哟入口国产精品| 日韩精品中文字| 欧美日韩成人免费| 97色在线观看免费视频| 国产成人av网| 亚洲欧美成人一区二区在线电影| 啪一啪鲁一鲁2019在线视频| 欧美日韩国产在线播放| 国产精品jvid在线观看蜜臀| 中文字幕精品—区二区| 国产精品久久久久免费a∨大胸| 日本三级久久久| 亚洲国产成人精品女人久久久| 色综合伊人色综合网站| 久久亚洲一区二区三区四区五区高| 国产精品va在线播放| 欧美性视频网站| 成人一区二区电影| 97精品视频在线观看| 91香蕉嫩草影院入口| 久久在线免费观看视频| 国产成人亚洲精品| 国产综合久久久久| 久久免费视频网| 日韩av片电影专区| 91国产视频在线播放| 欧美日韩国产成人高清视频| 久久久噜噜噜久久中文字免| 日韩av免费在线看| 国产aⅴ夜夜欢一区二区三区| 国产成人精品一区二区三区| 欧洲成人免费视频| 精品女同一区二区三区在线播放| 美日韩丰满少妇在线观看| 国外成人在线播放| 国产成人精彩在线视频九色| 亚洲精品白浆高清久久久久久| 国产精品男人的天堂| 亚洲欧美国产精品久久久久久久| 国产精品亚洲精品| 91精品国产综合久久香蕉最新版| 欧美精品在线第一页| 伊人久久男人天堂| 亚洲精品狠狠操| 91高清视频在线免费观看| 亚洲成人网av| 精品视频在线播放| 久久香蕉国产线看观看网| 欧美激情伊人电影| 欧美成aaa人片免费看| 国产精品一区二区女厕厕| 国产精品视频网| 午夜欧美大片免费观看| 国产欧美日韩精品在线观看| 欧美一级淫片aaaaaaa视频| 亚洲精品国产美女| 国产精品天天狠天天看| 国产在线观看精品一区二区三区| 综合网中文字幕| 激情懂色av一区av二区av| 久久综合久久美利坚合众国| 国产精品久久久一区| 国产玖玖精品视频| 欧美性猛交xxxx乱大交3| 欧美乱大交xxxxx| 日韩av在线免费观看一区| 最近中文字幕mv在线一区二区三区四区| 人人做人人澡人人爽欧美| 亚洲色图35p| 亚洲三级 欧美三级| 欧美性猛交xxxx黑人| 亚洲一区二区三区xxx视频| 69av在线播放| www.亚洲人.com| 国产亚洲精品日韩| 欧洲成人性视频| 日韩一区二区久久久| 国产美女被下药99| 5566日本婷婷色中文字幕97| 超碰精品一区二区三区乱码| 九九久久综合网站| 日韩av网站在线| 久久久999国产| 日本久久91av| 欧美国产日本在线| 国产偷国产偷亚洲清高网站| 亚洲男人的天堂网站| 亚洲综合在线小说| 亚洲男人天堂2019| 精品亚洲国产视频| 精品一区二区亚洲| 成人激情视频小说免费下载| 亚洲电影免费观看高清完整版在线观看| 精品二区三区线观看| 日韩有码片在线观看| 亚洲精品久久久一区二区三区| 亚洲欧美综合区自拍另类| 黄网站色欧美视频| 黄色一区二区在线观看| 91亚洲精品一区| 成人做爰www免费看视频网站| 91性高湖久久久久久久久_久久99| 一夜七次郎国产精品亚洲| 中文字幕日韩有码| 欧美日韩国产综合视频在线观看中文| 96精品视频在线| 亚洲网站在线播放| 成人免费视频a| 亚洲天堂男人天堂| 欧美性猛交xxxx乱大交3| 国产精品视频网址| 亚洲成人精品久久| 亚洲国产日韩一区| 在线精品国产成人综合| 久久久久久999| 亚洲人午夜精品| 国产亚洲精品久久久久动| 国产精品成人播放| 久久久精品一区| 中文字幕日韩在线播放| 国产一区二区欧美日韩| 5278欧美一区二区三区| 麻豆乱码国产一区二区三区| 欧美一级淫片播放口| 97成人精品视频在线观看| 亚洲欧美在线播放| 久久久久久久久久国产精品| 亚洲欧洲偷拍精品| 亚洲精品中文字幕有码专区| 国产精品久久久久久av| 精品久久久国产精品999| 日韩中文在线视频| 亚洲男子天堂网| 国产精品视频中文字幕91| 亚洲香蕉av在线一区二区三区| 91美女福利视频高清| 国产99久久精品一区二区永久免费| 日韩一区在线视频| 亚洲一区二区中文字幕| 欧洲s码亚洲m码精品一区| 亚洲精品一区二区在线| y97精品国产97久久久久久| 91久久精品久久国产性色也91| 一区二区在线免费视频| 日韩高清电影免费观看完整| 亚洲国产另类 国产精品国产免费| 国产亚洲一区精品| 伊人伊人伊人久久| 亚洲成人久久久| 精品中文字幕乱|