Bootstrap輪播(carousel)插件中圖片變形的終極解決方案——使用jqthumb.js

来源:http://www.cnblogs.com/nerd/archive/2016/07/09/5656158.html
-Advertisement-
Play Games

在頂求網的首頁中我使用了BootStrap的輪播(carousel)插件來展示文章中的圖片。我在程式中自動抓取文章的第一張圖片作為該輪播控制項中要顯示的圖片,由於文章的圖片大小不一,而輪播插件的大小基本是固定的,所以展示的時候圖片出現了變形。在網上找了很多中方式也沒有解決(過程曲折,不再贅述),直到找... ...


頂求網的首頁中我使用了BootStrap的輪播(carousel)插件來展示文章中的圖片。我在程式中自動抓取文章的第一張圖片作為該輪播控制項中要顯示的圖片,由於文章的圖片大小不一,而輪播插件的大小基本是固定的,所以展示的時候圖片出現了變形。在網上找了很多中方式也沒有解決(過程曲折,不再贅述),直到找到了這款Jquery的縮放插件——jqthumb.js.下麵來看看如何使用它以及如何利用它來控制輪播控制項中圖片的大小,而且能夠做到不變形,可以顯示圖片的主要部分(類似於微信朋友圈的圖片混排效果——不知道大家有沒有註意,在微信朋友圈中無論你發的圖片的比率是什麼,總能夠被完美的排列,而不會發生變形)。首先我們看看Bootstrap的Carousel的html代碼:

<div id="carousel-example-generic"  class="carousel slide" data-ride="carousel">
<!-- Wrapper for slides -->
  <div class="carousel-inner" role="listbox">
      <div class="item active">
      <a href="包含圖片一文章路徑">
          <img src="圖片一路徑" alt="圖片一" onload="DrawImage(this)"/></a>
          <div class="carousel-caption">
              <h4 class="alpha">
                  <a style="color:white;" href="包含圖片一文章路徑">圖片一標題</a>
              </h4>
             </div>
     
      </div>
      <div class="item">
     <a href="包含圖片二文章路徑">
         <img src="圖片二路徑" alt="圖片二" onload="DrawImage(this)"/>
     </a>
     <div class="carousel-caption">
              <h4 class="alpha">
                  <a style="color:white;" href="包含圖片二文章路徑">圖片二標題</a>
              </h4>
             </div>
     </div>
     <div class="item">
         <a href="包含圖片三文章路徑">
             <img src="圖片三路徑" alt="圖片三" onload="DrawImage(this)"/>
          </a>
          <div class="carousel-caption">
              <h4 class="alpha">
                  <a style="color:white;" href="包含圖片三文章路徑">圖片三標題</a>
              </h4>
             </div>
     </div>
  </div>

由上述代碼可以看到,每個圖片(img)在載入(onload)的時候都調用了一個函數DrawImage,在這個函數中我們就可以調用jqthumb.js的方法來控製圖片的大小了,註意該函數一定要加在上述HTML代碼前,否則第一次載入的時候控製圖片大小會失敗(因為頁面載入時序的原因),函數代碼如下:

<!--導入插件-->
<script type="text/javascript" src="/static/plugins/thumb/js/jqthumb.js"></script>
<script>
function DrawImage(hotimg)
{
   $(hotimg).jqthumb({
   classname      : 'jqthumb',
            width          : '100%',
            height         : '300px',
            position       : { y: '50%', x: '50%'},
            zoom           : '1',
            method         : 'auto',
   });
}
</script>

在該函數中我們調用了jqthumb方法來定義一個寬度和輪播插件相同高度為300px的原圖片的縮略圖,該縮略圖是由圖片的中心開始生成的(註意其position屬性的設置),這樣即使圖片的大小變化了,也可以顯示圖片的主要內容,而且圖片比率可以保持不變。

以上就是所有內容,希望能對大家有所幫助,轉載請註明來源為頂求網


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 概述 上一篇我們介紹瞭如何將$.ajax和Vue.js結合在一起使用,並實現了一個簡單的跨域CURD示例。Vue.js是數據驅動的,這使得我們並不需要直接操作DOM,如果我們不需要使用jQuery的DOM選擇器,就沒有必要引入jQuery。vue-resource是Vue.js的一款插件,它可以通過... ...
  • 經過今天的討論, 我們組初步給出了設計方案。 安裝了一晚上的 mockupBuilder 終於繪製了幾份界面的原型圖, 這裡需要吐槽下 mockupBuilder, 這個軟體很好用, 不過網頁版和單機版提供的功能不太一樣, 感覺單機版更全一些, 但是缺點是無法保存。。。 首頁:(初步設想是類似網易雲 ...
  • 一、表單 <form id="" name="" method="post/get" action="負責處理的服務端"> id不可重覆;name可重覆;get提交有長度限制,並且編碼後的內容在地址欄可見,post提交無長度限制,且編碼後內容不可見。 </form> 1、文本輸入 文本框<input ...
  • JavaScript對象與繼承 JavaScript是我在C語言之後接觸的第二門編程語言,大一暑假的時候在圖書館找了一本中國人寫的 "JavaScript" 程式設計來看。那個時候在編程方面幾乎還是小白,再加上那本書根本沒有提JavaScript的編程機制,又有一些誤導性的話,一直以來對JavaSc ...
  • 所有的函數都具有call(),apply()和bind()方法。它們可以在執行方法的時候用一個值指向this,並改變面向對象的作用域。 apply方法: 以下的兩種表達式是等價的: func(arg1,arg2,arg3) func.apply(null,[arg1,arg2,arg3]) appl ...
  • 我們可以用Math.random()的方法輕鬆的生成一個隨機的數字,但是這個數字可能是重覆的。有時候,我們需要一個不重覆的隨機數,以下提供了一種高效率的方法。 ...
  • 1.margin的百分比值 普通元素的百分比maigin相對於容器元素的寬度(width) 進行計算的。 這裡我們在圖片外面設置一個寬高分別為800 * 600的容器。設置img{ margin: 10%; } 結果如下 結果margin值都是 800 * 10% = 80px; 所以這裡都是相對於 ...
  • 很多剛剛接觸nodejs的初學者,都會經歷一個很繁冗的環境安裝過程。 一般主要要安裝nodejs,npm和express三樣東西。那麼這三樣東西分別是乾什麼的呢? 本篇文章就大致介紹一下這三樣東西分別是乾什麼的: nodejs 首先要說的是nodejs,既然我們要裝nodejs,那這個其實就沒什麼好 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...