DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery特效代碼 >> 使用jquery mobile做幻燈播放效果實現步驟
使用jquery mobile做幻燈播放效果實現步驟
編輯:JQuery特效代碼     
使用jquery mobile,可以很容易實現幻燈播放效果,下面講解下。
1、引入相關的jqury mobile類庫
. 代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title> jQuery Mobile Presentation</title>
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.1.1/jquery.mobile-1.1.1.min.css" />
<script src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
<script src="http://code.jquery.com/mobile/1.1.1/jquery.mobile-1.1.1.min.js"></script>

2、每個需要播放幻燈片的頁面基本結構
. 代碼如下:
<div data-role="page" id="slide1" data-theme="a" data-transition="fade">
<div data-role="header">
<h1>Slide 1</h1>
</div>
<div data-role="content">
</div>
</div>

3、接下來是每個幻燈片之間的來回導航了,代碼為
. 代碼如下:
var changeSlide = function(toSlide){
if(toSlide.length)
$.mobile.changePage( toSlide, { transition: toSlide.jqmData('transition') } );
};
// 返回主頁
var getHomeSlide = function(){
return $(':jqmData(role=page):first');
};
// go home
var goHome = function(){
changeSlide( getHomeSlide() );
return false;
};
// 到下一頁
var getNextSlide = function(slide){
return slide.next(':jqmData(role=page)');
};
//到下一頁
var goForward = function(){
changeSlide( getNextSlide($.mobile.activePage) );
return false;
};
// 獲得前一個頁面
var getPrevSlide = function(slide){
return slide.prev(':jqmData(role=page)');
};
// 跳到前一個頁面
var goBack = function(){
changeSlide( getPrevSlide($.mobile.activePage) );
return false;
};

注意一下,使用了 $.mobile.changePage方法來實現頁面的跳轉,並且跳轉是帶有
跳轉效果參數的,比如:
//transition to the "about us" page with a slideup transition
$.mobile.changePage( "about/us.html", { transition: "slideup"} );
//transition to the "search results" page, using data from a form with an id of "search"
$.mobile.changePage( "searchresults.php", {
type: "post",
data: $("form#search").serialize()
});
而return $(':jqmData(role=page):first');中,實際上jqmData是代替了
jquery的data選擇器了。
4、還有一個就是對左右箭頭的就是鍵盤按鍵的處理了,比如
. 代碼如下:
$(document).keydown(function(e) {
if(e.keyCode ==39) goForward(); //right
else if(e.keyCode ==37) goBack(); //left
})
.bind("swiperight", goForward )
.bind("swipeleft", goBack );

5、對導航條的處理
當每個幻燈片加載時,導航條自動加載到頁面的footer部分,
這個要在'pagebeforecreate前加載,
. 代碼如下:
$(':jqmData(role=page)').live( 'pagebeforecreate',function(event){
var slide = $(this);
// 找到footer
var footer = $(":jqmData(role=footer)", slide );
if( !footer.length ) {
//添加到頁面底部
footer = $('<div data-role="footer" data-position="fixed" data-fullscreen="true"/>').appendTo(slide);
};
// add nav. bar
footer.html('<div data-role="navbar">'+
'[list]'+
'[*]<a data-icon="back"></a>
'+
'[*]<a data-icon="home"></a>
'+
'[*]<a data-icon="forward"></a>
' +
'[/list]'+
'</div>');
// 處理前,後頁的點擊按鈕
var backButton = $(':jqmData(icon=back)', footer).click( goBack );
var homeButton = $(':jqmData(icon=home)', footer).click( goHome );
var forwardButton = $(':jqmData(icon=forward)', footer).click( goForward );
// 獲得前,後,主頁
var prevSlide = getPrevSlide( slide ), homeSlide = getHomeSlide(), nextSlide = getNextSlide( slide ) ;
// 是否存在前一頁,存在的話設置可以點擊的樣式
if( prevSlide.length ) {
backButton.attr('href', '#'+ prevSlide.attr('id') );
homeButton.attr('href', '#'+ homeSlide.attr('id') )
}else{
//禁止其按鈕
backButton.addClass('ui-disabled');
homeButton.addClass('ui-disabled')
};
// 是否存在後一頁
if( nextSlide.length ) {
forwardButton.attr('href', '#'+ nextSlide.attr('id') )
}else{
// 禁止其按鈕
forwardButton.addClass('ui-disabled')
};
//.........
});

6、根據情況加載圖片
如果幻燈片很多的話,不應該全部加載圖片,應該先加載小的圖片,並且可以根據屏幕大小判斷用什麼圖片,比如:
. 代碼如下:
<img src="empty.gif" class="photo"
data-small="..."
data-large="..."/>

判斷使用方法
. 代碼如下:
var loadImages = function(slide) {
var width = $(window).width();
//根據屏幕大小判斷使用圖片大小
var attrName = width > 480? 'large' : 'small';
$('img:jqmData('+attrName+')', slide).each(function(){
var img = $(this);
var source = img.jqmData(attrName);
if(source) img.attr('src', source).jqmRemoveData(attrName);
});
};

整個運行效果見:
http://moretechtips.googlecode.com/svn/mobile-presentation/index.htm
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved