DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 手機端實現Bootstrap簡單圖片輪播效果
手機端實現Bootstrap簡單圖片輪播效果
編輯:關於JavaScript     

個人電腦裡存了不少適合手機欣賞的圖片,但是放手機裡看是件很占據資源的事。鑒於家裡有一台電腦經常開著,正好用來做家庭局域網共享,於是筆者就設想通過一種比較簡單環保的思路。通過手機訪問電腦內的圖片。

首先是本地站點搭建:win+R輸入mmc打開控制台,文件-添加/刪除管理單元,Internet信息服務。添加確定,右側基本信息,新建網站-把路徑改了。設定一個端口號,手機浏覽器就可以輸入  電腦局域網ip:端口號 就可以連上去了。

接下來問題來了,一個個點擊查看然後關閉圖片是一件更不環保的事。何不做一個網頁訪問呢?最簡單的就是選項卡-輪播圖的模式。鑒於bootstrap的易適配性,就直接用它吧。 

一. 初始化設置:

按鈕組(ul-li-button)(太長,所有overflow hidden,需要滑動顯示),按鈕組是根據實際情況用DOM生成的,進入頁面默認顯示第一頁紅色高亮顯示。
跳轉按鈕:一文本輸入框,一個button風格的input
美圖展示區 

二. 頁面主要實現三個功能,每個功能要實現三類相似的效果:

1. 手指點擊頁面可以自動切換

左右區域被點擊
思路,做兩個透明的絕對定位div一左一右,覆蓋img層上方。點擊時可以觸發事件:
(1)按鈕組顏色變化
(2)按鈕組滑動
(3)圖片切換
這裡有個誰控制誰的問題,需要選取點擊一瞬間的紅色按鈕,然後變變藍,下一個(上一個)變紅。
(ul-li-button)體系中,按鈕組滑動距離應該是當前的基礎上前進或後退一個li的寬度單位。但是自適應的按鈕個位數和十位數寬度不同。需要分類討論之。
圖片根據變化後紅色按鈕內的序號改變顯示的圖片。
所以是序列按鈕控制所有功能 

2.點擊按鈕頁面切換

事件——序列按鈕被點擊
(1)點擊按鈕顏色變化——被點擊的按鈕變紅,其它變藍——不難
(2)按鈕組滑動目標位置——用的是當前按鈕的left值,加上少算ul-lipadding的15——就算出了當前button相對於ul的偏移。然後,把此偏移作為ul相對於顯示區的偏移值。(如果願意,可以加上一個值,讓按鈕看起來居中)
(3)圖片切換,根據變化後紅色按鈕內的序號改變顯示的圖片。
此過程1依然是序列按鈕控制所有功能。 

3.輸入跳轉
事件——跳轉按鈕被點擊
(1)按鈕變色,根據輸入框內的value值,用原生js把該含有該序號的按鈕選出來。變紅
(2)按鈕組滑動——跟前面一樣
(2)圖片切換,跟前面一樣。
此過程是輸入框控制頁面的所有功能。 

根據這個思想,大致的功能就實現了。 

三 .有幾個原則:
(1)動畫控制:手持設備的特性允許用戶以很快的手速點擊屏幕,頻繁地觸發事件導致按鈕不能停止。可以用判斷動畫函數來阻止運行。但是這樣做讓頁面生硬。可以考慮用淡出——改變圖片路徑(延遲執行)——淡入的方式,及解決了快手速用戶問題,也能在一定程度上提升柔和感,
(2)極限控制,當第一頁和最後一頁時,應阻止用戶再操作。
(3)圖片為了網頁應該做一定的修改,本例采用的圖片命名為xxx (1) ,xxx (2)。。。。的方式,因為有一個流水號所以DOM操作起來很方便。

四. 進一步應用

寫了那麼多代碼,只用在一個套圖頁面上面,就太不環保了。所以把它們封裝為函數。傳入兩個參數:url 和 imgNum分別代表圖片路徑和套圖數量。
url是一個字符串,必須滿足下面要求:
圖片文件名必須夾雜 “(流水號)”,對文件夾名等無要求,比如 “文靜/wenjing().jjpg” 系列流水號由js生成。所以不用寫。
實現手段是slice()方法。 

五.問題

首次加載時動畫顯示滯後,是因為需要時間下載所致,可以通過適當延長動畫時間。在家庭共享環境下,可以忽略這個問題。
可能存在因為bootstrap特性,所以有若干自定樣式的表現不符合設計的規范。 

效果圖:(適配ip6)

 

demo地址:(建議手機觀看)http://djtao.top/ugirl/ 

代碼清單html 

<!DOCTYPE html>
<html lang="zh-cn">
 <head>
  <!--頁面編碼 -->
  <meta charset="UTF-8">
  <!--低版本浏覽器模擬渲染-->
   
  <meta name="viewport" content="width=device-width, initialscale=
1, maximumscale=1, user-scalable=no">
  <meta name="viewport" content="width=deviece-width,initial-scale=1">
   
  <!--支持國產浏覽器的高速渲染-->
  <meta name="renderer" content="Webkit">
  <!--在此進行SEO設置:作者、關鍵詞、描述-->
  <meta name="author" content="djtao">
  <meta name="keywords" content="djtao">
  <meta name="description" content="djtao">
   
  <title>Ugirl</title>
   
  <!--bootstrap-->
   
  <!--以下兩個js插件用於在IE8及以下支持H5元素查詢的,如不用可移除 -->
  <!--[if lt IE 9]>
   <script src="scripts/html5.min.js"></script>
   <script src="scripts/respond.min.js"></script>
  <![endif]-->
   
  <!--bootstrap樣式文件 -->
  <link rel="stylesheet" href="bootstrap/css/bootstrap.css">
  <!--自定義樣式文件 -->
  <link rel="stylesheet" href="styles/css.css">
   
  <!--基於jQuery的腳本文件 -->
  <script src="scripts/jquery.min.js"></script>
  <!-- bootstrap的jq插件 -->
  <script src="bootstrap/js/bootstrap.min.js"></script>
  <!--自定義腳本文件 -->
  <script src="scripts/js.js"></script>
   
   
   
 </head>
 <body class="container">
  <header>
   <h1>Ugirl <small>專業的秘密</small></h1>
  </header>
  <div id="main" class="row">
   <div id="btn-group" class="col-xs-6">
    <ul id="list" class="list-inline"></ul>
   </div>
   <div class="col-xs-6">
     <form class="form-horizontal">
      <div class="form-group has-success">
       <div class="col-xs-6"><input class="form-control" id="num" style="width:100%" col="2" type="text"></div>
       <div class="col-xs-2"><input type="button" value="jump" class="btn btn-default">
      </div>
     </form>
    </div>
   </div>
  </div>
  <div class="row">
   <div id="box" class="col-xs-12">
    <div id="last"></div>
    <div id="next"></div>
    <img class="img-responsive" src="img/wenjing/wenjing (1).jpg">
   </div> 
  </div>
  
   
 </body>
</html>

css

body{
 background: #f2f2f2;
}
#box{
 position: relative;
}
#next{
 width:50%;height:500px;
 position: absolute;
 left:50%;
}
#last{
 width:50%;height:500px;
 position: absolute;
 
}
#btn-group{
 height: 40px;
 overflow: hidden;
}
#list{
 list-style: none;
 position: absolute;
}
#list>li{
 list-style: none;
 float: left;
 position: relative;
}
#main{
 margin-top: 20px;
}
 

javascript

function Ugirl(url,imgNum){
  
 var aBtn=document.getElementsByTagName('button');
 $('#list').css('width',(imgNum*(52))+'px');
 var str=url;
 var index=0;
 for(i=0;i<str.length;i++){
  if(str.slice(i-1,i)=='('){
   index=i;
  }
 }
 var a=str.slice(0,index);
 var b=str.slice(index);
 //分割url字符串
 for(j=1;j<=imgNum;j++){
  var $btn = $('<li><button class="btn btn-primary">'+j+'</button></li>');
  $btn.appendTo($('#list'));
 }
 aBtn[0].className='btn btn-danger';
 //按鈕初始化設置
 //手指點擊事件
 $('#box div').click(function(){
   
  if($(this).attr('id')=='next'){//下一個
   if($('.btn-danger') .html()==imgNum){
    alert('到底了哦');
    return false;
   }
   liWidth=44;
   liWidth2=52;
    
   $('.btn-danger').removeClass().addClass('btn btn-primary')
    .parent().next().children().removeClass().addClass('btn btn-danger');
  
  }else if($(this).attr('id')=='last'){//上一個
   if($('.btn-danger') .html()==1){
    alert('到頂了哦');
    return false;
   }else{
    $('.btn-danger').removeClass().addClass('btn btn-primary')
     .parent().prev().children().removeClass().addClass('btn btn-danger');
    liWidth=-44;
    liWidth2=-52;
   } 
  }else{
   return false;
  };
  //個位數按鈕和10位數按鈕寬度不同。所以設置兩個
  if($('.btn-danger') .html()<=10){
    
   $('#list').animate({left:'-='+liWidth+'px'},400);
    
  }else if($('.btn-danger') .html()>10){
    
   $('#list').animate({left:'-='+liWidth2+'px'},400);
  }
  //大圖切換
  $('img').fadeOut(200);
  setTimeout(function(){
   $('img').attr('src',a+$('.btn-danger') .html()+b);
  },220)
  $('img').fadeIn(300);
 });
 //選項按鈕點擊
 $('button').click(function(){ 
  $('button').attr('class','btn btn-primary');
  $(this).attr('class','btn btn-danger');
  var moveLength=-$(this).parent().position().left+15;
  $('#list').animate({left:moveLength+'px'},400);
  $('img').attr('src',a+$('.btn-danger') .html()+b); 
   
 });
 //跳轉按鈕點擊
 $('.btn-default').click(function(){
  var s=$('#num').val();
  if(s<1||s>imgNum){
   return false;
   alert('沒有那麼多哦')
  }//極限設置
  var pageNum=$('.btn-danger') .html();
  $('img').attr('src',a+s+b);
  $('#list').children().children().removeClass().addClass('btn btn-primary');
  $(aBtn[s-1]).removeClass().addClass('btn btn-danger');
  var moveLength=-$(aBtn[s-1]).parent().position().left+15;
  $('#list').animate({left:moveLength+'px'},400);
 })
}
$(function(){
 Ugirl('img/wenjing/wenjing ().jpg',65);
})//在其它頁面也引入了Ugirl函數後,就可以直接調用直接調用

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved