jQuery圖片查看插件Magnify開(kāi)發(fā)詳解
前言
因?yàn)橐恍┨厥獾臉I(yè)務(wù)需求,經(jīng)過(guò)一個(gè)多月的蟄伏及思考,我開(kāi)發(fā)了這款 jQuery 圖片查看器插件 Magnify,它實(shí)現(xiàn)了 Windows 照片查看器的所有功能,比如模態(tài)窗的拖拽、調(diào)整大小、最大化,圖片的縮放、旋轉(zhuǎn),平移、鍵盤(pán)控制等。插件的樣式都是最基礎(chǔ)的 CSS,定制非常容易,可以輕松修改成自己喜歡的樣式。隨后會(huì)陸續(xù)發(fā)布 React 及 Vue 相關(guān)版本的插件。本文主要介紹插件的特點(diǎn)及使用方法,而關(guān)于插件開(kāi)發(fā)的細(xì)節(jié)將會(huì)在之后的具體文章中說(shuō)明。
Github: https://github.com/nzbin/magnify
Website: https://nzbin.github.io/magnify
開(kāi)發(fā)小記
由于最近工作繁忙,幾乎每天都是晚上十點(diǎn)到家,然后開(kāi)始編寫(xiě)插件,睡覺(jué)時(shí)已過(guò)凌晨,如今身心俱疲。因?yàn)闆](méi)有找到相關(guān)的插件,所以很多問(wèn)題都是絞盡腦汁獨(dú)立思考,比如以鼠標(biāo)為中心縮放圖片、改變彈窗大小時(shí)對(duì)圖片移動(dòng)的限制、圖片旋轉(zhuǎn)之后的縮放、平移等問(wèn)題,而開(kāi)發(fā)插件最讓人頭疼的就是細(xì)節(jié),甚至大部分時(shí)間是在修復(fù)單一功能的 bug 。
另外,開(kāi)發(fā)插件的最大難度不是功能實(shí)現(xiàn),而是如何設(shè)計(jì)插件,如何讓插件的使用更簡(jiǎn)單、更方便。關(guān)于如何設(shè)計(jì)插件并不是本篇文章的重點(diǎn),我會(huì)在之后專(zhuān)門(mén)寫(xiě)一篇介紹插件設(shè)計(jì)思想的文章。
插件所有的代碼幾乎都是在調(diào)整彈窗或者圖片的 width、height、left、top ,所以兼容性問(wèn)題不大,主要是 2D 旋轉(zhuǎn)問(wèn)題,IE 9 以下需要使用濾鏡實(shí)現(xiàn)。為了方便調(diào)整樣式,其中有很多相對(duì)位置的計(jì)算。
Magnify 采用了文件分離的方式編寫(xiě),使用 npm 插件打包,并沒(méi)有使用新語(yǔ)法,也沒(méi)有使用現(xiàn)在流行的打包工具。使用 npm 工具已經(jīng)是項(xiàng)目開(kāi)發(fā)打包發(fā)布的一個(gè)趨勢(shì)。
演示
如果你不想點(diǎn)開(kāi)網(wǎng)址查看示例的話(huà),可以通過(guò)下面的 CodePen 查看插件效果,除了視窗的大小之外,兩種方式?jīng)]有任何區(qū)別:
如果你的網(wǎng)速和其他原因不能打開(kāi) CodePen 的話(huà),可以查看下面的圖片演示。
主要功能
Magnify 的功能可以參考 Windows 照片查看器,基本完成了可以實(shí)現(xiàn)的所有功能。
1.模態(tài)窗拖拽
如果圖片尺寸不大于展示區(qū)域,通過(guò)圖片展示區(qū)域也可以拖拽彈窗。這和 QQ 圖片查看器的操作方式是相同的。
2.模態(tài)窗調(diào)整大小
目前的調(diào)整大小存在一點(diǎn) bug,但不影響整體的使用。
3.模態(tài)窗最大化
除了彈窗最大化,開(kāi)發(fā)初期也設(shè)計(jì)了最小化的功能,但感覺(jué)有些雞肋,所以暫時(shí)沒(méi)有添加。
4.圖片縮放
可以通過(guò)鼠標(biāo)滾輪、按鈕、鍵盤(pán)等操作
5.圖片旋轉(zhuǎn)
目前的圖片旋轉(zhuǎn)功能還沒(méi)有添加支持 IE9 以下版本的代碼。
6.鍵盤(pán)控制
Magnify 和 Windows 照片查看器的按鍵是一樣的
←
上一張 →
下一張 +
放大 -
縮小 ctrl + alt + 0
實(shí)際尺寸 ctrl + ,
向左旋轉(zhuǎn) ctrl + .
向右旋轉(zhuǎn) 7.全屏顯示
Magnify 的全屏顯示只實(shí)現(xiàn)了基本的展示功能,還沒(méi)有實(shí)現(xiàn)幻燈片自動(dòng)輪播的功能。全屏環(huán)境下使用鍵盤(pán)控制圖片。
使用方法
Magnify 的使用和其他大多數(shù) lightbox 插件的用法并沒(méi)有兩樣,如果你習(xí)慣了其它插件的使用,使用 Magnify 也不會(huì)有任何障礙。
1.需要引用的文件
<link href="/path/to/magnify.css" rel="external nofollow" rel="stylesheet"> <script src="/path/to/jquery.js"></script> <script src="/path/to/jquery.magnify.js"></script>
Magnify 默認(rèn)使用 font-awesome 的圖標(biāo),所以需要引用 font-awesome 的 css 文件。如果你想使用其它圖標(biāo),可以修改 options 的 icons 參數(shù)。在之后的版本中,我可能會(huì)添加定制的字體圖標(biāo)文件或者使用 svg 圖標(biāo)。
<link rel="external nofollow" rel="stylesheet">
2.HTML 結(jié)構(gòu)
Magnify 默認(rèn)使用以下結(jié)構(gòu),這樣的結(jié)構(gòu)可以做兼容處理,也是大多數(shù) lightbox 使用的結(jié)構(gòu)。
<a data-magnify="gallery" href="big-1.jpg" rel="external nofollow" > <img src="small-1.jpg"> </a> <a data-magnify="gallery" href="big-2.jpg" rel="external nofollow" > <img src="small-2.jpg"> </a> <a data-magnify="gallery" href="big-3.jpg" rel="external nofollow" > <img src="small-3.jpg"> </a>
也可以使用下面更簡(jiǎn)潔的結(jié)構(gòu)
<img data-magnify="gallery" data-src="big-1.jpg" src="small-1.jpg"> <img data-magnify="gallery" data-src="big-2.jpg" src="small-2.jpg"> <img data-magnify="gallery" data-src="big-3.jpg" src="small-3.jpg">
Magnify 的 HTML 結(jié)構(gòu)包含以下幾個(gè)選項(xiàng)
添加 data-src
屬性可以鏈接到大圖。如果在 <a>
標(biāo)簽中使用,它會(huì)覆蓋 href
屬性的值。添加 data-caption
屬性可以顯示標(biāo)題。如果你不使用這個(gè)屬性,插件會(huì)顯示 URL 中的圖片名。添加 data-group
屬性可以對(duì)圖片分組。 3.初始化插件
如果在 HTML 中添加 data-magnify
屬性,插件會(huì)自動(dòng)初始化。
手動(dòng)初始化插件的方法和所有 jQuery 插件一樣:
$('[data-magnify=gallery]').magnify(options);
參數(shù)配置
options = { draggable: true, resizable: true, movable: true, keyboard: true, title: true, modalWidth: 320, modalHeight: 320, fixedContent: true, fixedModalSize: false, initMaximized: false, gapThreshold: 0.02, ratioThreshold: 0.1, minRatio: 0.1, maxRatio: 16, headToolbar: [ 'maximize', 'close' ], footToolbar: [ 'zoomIn', 'zoomOut', 'prev', 'fullscreen', 'next', 'actualSize', 'rotateRight' ], icons: { maximize: 'fa fa-window-maximize', close: 'fa fa-close', zoomIn: 'fa fa-search-plus', zoomOut: 'fa fa-search-minus', prev: 'fa fa-arrow-left', next: 'fa fa-arrow-right', fullscreen: 'fa fa-photo', actualSize: 'fa fa-arrows-alt', rotateLeft: 'fa fa-rotate-left', rotateRight: 'fa fa-rotate-right' } }
關(guān)于插件參數(shù)的具體含義,我就不在此復(fù)制黏貼了,請(qǐng)大家參考 官方文檔 的詳細(xì)說(shuō)明。如有問(wèn)題,可以在此留言。
自定義樣式
因?yàn)椴寮臉邮奖容^簡(jiǎn)單,所以修改起來(lái)也非常容易。除了 Windows 照片查看器,QQ 的圖片查看器也非常的高大上。我們只要簡(jiǎn)單修改就可以實(shí)現(xiàn) QQ 圖片查看器的效果,但是部分功能比如縮略圖還沒(méi)有實(shí)現(xiàn)。以下是實(shí)時(shí)演示:
面對(duì)這樣的圖片查看器足以令人心曠神怡~
總結(jié)
目前插件整體已經(jīng)趨于完善,但仍然有很多需要修改及添加的細(xì)節(jié),尤其對(duì)移動(dòng)端的支持,大家可以 star 一下隨時(shí)關(guān)注項(xiàng)目的更新動(dòng)態(tài)。關(guān)于插件的介紹就不再贅述了,如果大家發(fā)現(xiàn)了 Bug 或者有更好的建議,可以在GitHub中提問(wèn),也可以在此留言,大家的支持是我前進(jìn)的最大動(dòng)力!如果這款插件對(duì)你有幫助或者你在項(xiàng)目中使用了這款插件,歡迎留言告知!
相關(guān)文章
jQuery的Ajax接收java返回?cái)?shù)據(jù)方法
今天小編就為大家分享一篇jQuery的Ajax接收java返回?cái)?shù)據(jù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08jquery實(shí)現(xiàn)紅色豎向多級(jí)向右展開(kāi)的導(dǎo)航菜單效果
這篇文章主要介紹了jquery實(shí)現(xiàn)紅色豎向多級(jí)向右展開(kāi)的導(dǎo)航菜單效果,涉及jquery鼠標(biāo)hover事件結(jié)合class樣式動(dòng)態(tài)添加與刪除的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08使用jQuery實(shí)現(xiàn)星級(jí)評(píng)分代碼分享
本文給大家分享的是一段使用jQuery制作的星級(jí)評(píng)分的代碼,非常大氣漂亮,功能也很實(shí)用,這里推薦個(gè)大家。2014-12-12基于JQuery的6個(gè)Tab選項(xiàng)卡插件
今天在修整博客側(cè)欄信息時(shí),利用到了Tab選項(xiàng)卡方式,因?yàn)閆Blog封裝的是JQuery庫(kù),所以很自然地就想到了IdTabs。2010-09-09jquery1.4.2 for Visual studio 2010 模板文件
剛把最新的1.4.2 版jquery 整理進(jìn)了vs2010,每次建項(xiàng)目就能直接用了.文件好多.累死了..2010-07-07查看源碼的工具 學(xué)習(xí)jQuery源碼不錯(cuò)的工具
jQuery是一個(gè)非常好用的javascript框架,我尤其喜歡它強(qiáng)大的選擇器和鏈?zhǔn)奖磉_(dá)式,使得我們能通過(guò)簡(jiǎn)單的語(yǔ)句實(shí)現(xiàn)復(fù)雜的功能。它還有一個(gè)重要的特點(diǎn)就是它的可擴(kuò)展性,使得很多人都可以開(kāi)發(fā)他們的插件并且分享出來(lái)2011-12-12