搜尋
首頁web前端js教程圖片查看外掛程式Magnify使用詳解

這次帶給大家圖片查看外掛Magnify使用詳解,使用圖片查看外掛Magnify的注意事項有哪些,以下就是實戰案例,一起來看一下。

前言

因為一些特殊的業務需求,經過一個多月的蟄伏及思考,我開發了這款jQuery 圖片檢視器外掛程式Magnify,它實現了Windows 照片檢視器的所有功能,例如模態窗的拖曳、調整大小、最大化,圖片的縮放、旋轉,平移、鍵盤控制等。外掛的樣式都是最基本的 CSS,客製化非常容易,可以輕鬆修改成自己喜歡的樣式。隨後會陸續發布 React 及 Vue 相關版本的插件。本文主要介紹插件的特點及使用方法,而關於插件開發的細節將會在之後的具體文章中說明。

開發小記

由於最近工作繁忙,幾乎每天都是晚上十點到家,然後開始寫插件,睡覺時已過凌晨,如今身心俱疲。因為沒有找到相關的插件,所以很多問題都是絞盡腦汁獨立思考,例如以滑鼠為中心縮放圖片、改變彈窗大小時對圖片移動的限制、圖片旋轉之後的縮放、平移等問題,而開發插件最讓人頭痛的就是細節,甚至大部分時間都在修復單一功能的bug 。

另外,開發插件的最大難度不是功能實現,而是如何設計插件,如何讓插件的使用更簡單、更方便。關於如何設計插件並不是本篇文章的重點,我會在之後專門寫一篇介紹插件設計想法的文章。

外掛程式所有的程式碼幾乎都是在調整彈跳窗或圖片的 width、height、left、top ,所以相容性問題不大,主要是 2D 旋轉問題,IE 9 以下需要使用濾鏡實作。為了方便調整樣式,其中有許多相對位置的計算。

Magnify 採用了檔案分離的方式編寫,使用 npm 外掛程式打包,並沒有使用新語法,也沒有使用現在流行的打包工具。使用 npm 工具已經是專案開發打包發布的趨勢。

示範

如果你不想點開網址查看範例的話,可以透過下面的CodePen 檢視外掛程式效果,除了視窗的大小之外,兩種方式沒有任何差別:

如果你的網路速度和其他原因不能打開CodePen 的話,可以查看下面的圖片示範。

主要功能

Magnify 的功能可以參考 Windows 照片檢視器,基本上完成了所有可以實現的功能。

1.模態視窗拖曳

如果圖片尺寸不大於展示區域,透過圖片展示區域也可以拖曳彈跳窗。這和 QQ 圖片檢視器的操作方式是相同的。

2.模態視窗調整大小

目前的調整大小存在一點bug,但不影響整體的使用。

3.模態窗最大化

除了彈跳視窗最大化,開發初期也設計了最小化的功能,但感覺有些雞肋,所以暫時沒有添加。

4.圖片縮放

可以透過滑鼠滾輪、按鈕、鍵盤等動作

5.圖片旋轉

#目前的圖片旋轉功能還沒有加入支援IE9 以下版本的程式碼。

6.鍵盤控制

#Magnify 和Windows 相片檢視器的按鍵是相同的

上一張 下一張+# 放大- 縮小ctrl + alt + 0實際尺寸ctrl + , 向左旋轉ctrl + . 向右旋轉7.全螢幕顯示

Magnify 的全螢幕顯示只實現了基本的展示功能,還沒有實現幻燈片自動輪播的功能。全螢幕環境下使用鍵盤控制圖片。

使用方法

Magnify 的使用和其他大多數lightbox 外掛程式的用法並沒有兩樣,如果你習慣了其它外掛程式的使用,使用Magnify 也不會有任何障礙。

1.需要引用的檔案

<link>
<script></script>
<script></script>

Magnify 預設使用 font-awesome 的圖標,所以需要引用 font-awesome 的 css 檔案。如果你想使用其它圖標,可以修改 options 的 icons 參數。在之後的版本中,我可能會添加自訂的字體圖示檔案或使用 svg 圖示。

<link>

2.HTML 結構

Magnify 預設使用下列結構,這樣的結構可以做相容處理,也是大多數 lightbox 所使用的結構。

<a>
 <img  src="/static/imghwm/default1.png" data-src="small-1.jpg" class="lazy" alt="圖片查看外掛程式Magnify使用詳解" >
</a>
<a>
 <img  src="/static/imghwm/default1.png" data-src="small-2.jpg" class="lazy" alt="圖片查看外掛程式Magnify使用詳解" >
</a>
<a>
 <img  src="/static/imghwm/default1.png" data-src="small-3.jpg" class="lazy" alt="圖片查看外掛程式Magnify使用詳解" >
</a>

也可以使用下面更簡潔的結構

<img  src="/static/imghwm/default1.png" data-src="big-1.jpg" class="lazy" alt="圖片查看外掛程式Magnify使用詳解" >
<img  src="/static/imghwm/default1.png" data-src="big-2.jpg" class="lazy" alt="圖片查看外掛程式Magnify使用詳解" >
<img  src="/static/imghwm/default1.png" data-src="big-3.jpg" class="lazy" alt="圖片查看外掛程式Magnify使用詳解" >

Magnify 的HTML 結構包含以下幾個選項

新增src 屬性可以連結到大圖。如果在 <a></a> 標籤中使用,它會覆寫 href 屬性的值。新增 data-caption 屬性可以顯示標題。如果你不使用這個屬性,外掛程式會顯示 URL 中的圖片名稱。新增 data-group 屬性可以對圖片分組。 3.初始化外掛程式

如果在 HTML 中加入 data-magnify 屬性,外掛程式會自動初始化。

手動初始化插件的方法和所有jQuery 插件一樣:

$('[data-magnify=gallery]').magnify(options);

參數配置

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'
  }
}

關於插件參數的具體含義,我就不在此複製粘貼了,請大家參考官方文件的詳細說明。如有問題,可以在此留言。

自訂樣式

因為外掛程式的樣式比較簡單,所以修改起來也非常容易。除了 Windows 照片檢視器,QQ 的圖片檢視器也非常的高大。我們只要簡單修改就可以實現 QQ 圖片檢視器的效果,但是部分功能例如縮圖還沒實現。

面對這樣的圖片檢視器足以令人心曠神怡~

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

jquery動態合併儲存格

#JS實作表格中相同儲存格合併

以上是圖片查看外掛程式Magnify使用詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Java vs JavaScript:開發人員的詳細比較Java vs JavaScript:開發人員的詳細比較May 16, 2025 am 12:01 AM

javaandjavascriptaredistinctlanguages:javaisusedforenterpriseandmobileapps,while javascriptifforInteractiveWebpages.1)JavaisComcompoppored,statieldinglationallyTypted,statilly tater astrunsonjvm.2)

JavaScript數據類型:瀏覽器和nodejs之間是否有區別?JavaScript數據類型:瀏覽器和nodejs之間是否有區別?May 14, 2025 am 12:15 AM

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScript評論:使用//和 / * * / * / * /JavaScript評論:使用//和 / * * / * / * /May 13, 2025 pm 03:49 PM

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python vs. JavaScript:開發人員的比較分析Python vs. JavaScript:開發人員的比較分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

Python vs. JavaScript:選擇合適的工具Python vs. JavaScript:選擇合適的工具May 08, 2025 am 12:10 AM

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript:了解每個的優勢Python和JavaScript:了解每個的優勢May 06, 2025 am 12:15 AM

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)