使用jquery mobile做幻燈播放效果實現步驟
更新時間:2013年01月04日 11:42:18 作者:
使用jquery mobile,可以很容易實現幻燈播放效果,擺脫繁雜的步驟輕松實現,接下來介紹,有需要的朋友可以參考下
使用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" />
<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
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" />
<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
您可能感興趣的文章:
- jQuery Mobile框架中的表單組件基礎使用教程
- jquery-mobile基礎屬性與用法詳解
- 使用jQueryMobile實現滑動翻頁效果的方法
- jquerymobile局部渲染的各種刷新方法小結
- jquery mobile實現撥打電話功能的幾種方法
- 讓jQuery Mobile不顯示討厭loading界面的方法
- jquery mobile頁面跳轉后樣式丟失js失效的解決方法
- jQuery Mobile彈出窗、彈出層知識匯總
- jQuery Mobile的loading對話框顯示/隱藏方法分享
- jQueryMobile之Helloworld與頁面切換的方法
- JQuery動態(tài)創(chuàng)建DOM、表單元素的實現代碼
- jquery-mobile表單的創(chuàng)建方法詳解
相關文章
基于JQuery的動態(tài)刪除Table表格的行和列的代碼
基于JQuery的動態(tài)刪除Table表格的行和列的代碼以前腳本之家也發(fā)布過相關的代碼,大家可以參考下。2011-05-05
jQuery EasyUI API 中文文檔 - Form表單
jQuery EasyUI API 中文文檔 - Form表單,使用jQuery EasyUI的朋友可以參考下。2011-10-10
使用jQuery的easydrag插件實現可拖動的DIV彈出框
EasyDrag 是一個用來實現頁面元素拖拉的 jQuery 插件。接下來通過本文給大家介紹使用jQuery的easydrag插件實現可拖動的DIV彈出框,感興趣的朋友一起學習吧2016-02-02
jQuery實現的給圖片點贊+1動畫效果(附在線演示及demo源碼下載)
這篇文章主要介紹了jQuery實現的給圖片點贊+1動畫效果,并附帶在線演示及demo源碼下載,涉及jQuery鼠標事件響應及頁面元素屬性動態(tài)操作相關技巧,需要的朋友可以參考下2015-12-12
淺析jQuery中調用ajax方法時在不同瀏覽器中遇到的問題
這篇文章主要介紹了jQuery中調用ajax方法時在不同瀏覽器中遇到的問題,因不同瀏覽器默認設置的不同造成的問題2014-06-06

