這篇文章主要為大家詳細介紹了基於Bootstrap的簡單輪播圖的手機實現,具有一定的參考價值,感興趣的小伙伴們可以參考一下
個人電腦裡存了不少適合手機欣賞的圖片,但是放手機裡看是件很佔據資源的事。鑑於家裡有一台電腦經常開著,正好用來做家庭區域網路共享,於是筆者就設想透過一種比較簡單環保的想法。透過手機存取電腦內的圖片。
首先是本機網站建置:win R輸入mmc開啟控制台,檔案-新增/刪除管理單元,Internet資訊服務。添加確定,右側基本訊息,新網站-把路徑改了。設定一個連接埠號,手機瀏覽器就可以輸入 電腦區域網路ip:連接埠號碼 就可以連上去了。
接下來問題來了,一個個點擊查看然後關閉圖片是一件更不環保的事。 何不做一個網頁訪問呢? 最簡單的就是選項卡-輪播圖的模式。鑑於bootstrap的易適配性,就直接用它吧。
一.初始化設定:
按鈕組(ul-li-button)(太長,所有overflow hidden,需要滑動顯示) ,按鈕組是根據實際情況用DOM產生的,進入頁面預設顯示第一頁紅色高亮顯示。
跳轉按鈕:一文字輸入框,一個button風格的input
美圖展示區
二. 頁面主要實現三個功能,每個功能要實現三類相似的效果:
1. 手指點擊頁面可以自動切換
左右區域被點擊
思路,做兩個透明的絕對定位p一左一右,覆蓋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> <p id="main" class="row"> <p id="btn-group" class="col-xs-6"> <ul id="list" class="list-inline"></ul> </p> <p class="col-xs-6"> <form class="form-horizontal"> <p class="form-group has-success"> <p class="col-xs-6"><input class="form-control" id="num" style="width:100%" col="2" type="text"></p> <p class="col-xs-2"><input type="button" value="jump" class="btn btn-default"> </p> </form> </p> </p> </p> <p class="row"> <p id="box" class="col-xs-12"> <p id="last"></p> <p id="next"></p> <img class="img-responsive" src="img/wenjing/wenjing (1).jpg"> </p> </p> </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; }
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 p').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函数后,就可以直接调用直接调用
以上是手機端實現Bootstrap圖片輪播的效果的詳細內容。更多資訊請關注PHP中文網其他相關文章!