Bootstrap輪播插件中圖片變形的終極解決方案 使用jqthumb.js
來源:易賢網(wǎng) 閱讀:741 次 日期:2016-07-29 14:05:12
溫馨提示:易賢網(wǎng)小編為您整理了“Bootstrap輪播插件中圖片變形的終極解決方案 使用jqthumb.js”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了Bootstrap輪播插件中圖片變形的終極解決方案,使用jqthumb.js,感興趣的小伙伴們可以參考一下

在頂求網(wǎng)的首頁中我使用了BootStrap的輪播(carousel)插件來展示文章中的圖片。我在程序中自動抓取文章的第一張圖片作為該輪播控件中要顯示的圖片,由于文章的圖片大小不一,而輪播插件的大小基本是固定的,所以展示的時候圖片出現(xiàn)了變形。在網(wǎng)上找了很多中方式也沒有解決(過程曲折,不再贅述),直到找到了這款Jquery的縮放插件——jqthumb.js.下面來看看如何使用它以及如何利用它來控制輪播控件中圖片的大小,而且能夠做到不變形,可以顯示圖片的主要部分(類似于微信朋友圈的圖片混排效果——不知道大家有沒有注意,在微信朋友圈中無論你發(fā)的圖片的比率是什么,總能夠被完美的排列,而不會發(fā)生變形)。首先我們看看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)的時候都調(diào)用了一個函數(shù)DrawImage,在這個函數(shù)中我們就可以調(diào)用jqthumb.js的方法來控制圖片的大小了,注意該函數(shù)一定要加在上述HTML代碼前,否則第一次加載的時候控制圖片大小會失敗(因為頁面加載時序的原因),函數(shù)代碼如下: 

<!--導(dǎo)入插件-->

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

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

以上就是所有內(nèi)容,希望能對大家有所幫助

更多信息請查看網(wǎng)絡(luò)編程
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65317125(9:00—18:00) 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)