jQuery 標題的自動翻轉(zhuǎn)實現(xiàn)代碼
更新時間:2009年10月14日 17:32:39 作者:
我們平時在開發(fā)web程序的時候,想把一個新聞源滾動顯示新聞的條目的標題及內(nèi)容摘要,而且是每次一條,有點類似csdn的滾動廣告。
即一條新聞滾 進視圖之后,會暫停幾秒鐘,然后繼續(xù)向上2滾動,淡出視圖,同時,下一條新聞接著滾入視圖。這次主要是用jquery來開發(fā)這個功能,里面肯定有許多不足 之處,歡迎大家點評。
先粘貼一下代碼,
<style>
<%-- #news-feed
{
padding: 0;
margin: 0 0 0 10px;
position: relative;
height: 200px;
width: 17em;
overflow: hidden;
}
.headline
{
position: absolute;
height: 200px;
top: 210px;
overflow: hidden;
}--%>
</style>
<script type="text/javascript">
$(document).ready(function() {
$('#news-feed').each(function() {
var $container = $(this);
$container.empty();
$.get('feed.xml', function(data) {
$('rss item', data).each(function() {
var $link = $('<a></a>')
.attr('href', $('link', this).text())
.text($('title', this).text());
var $headline = $('<h4></h4>').append($link);
var pubDate = new Date($('pubDate', this).text());
var pubMonth = pubDate.getMonth() + 1;
var pubDay = pubDate.getDate();
var pubYear = pubDate.getFullYear();
var $publication = $('<div></div>')
.addClass('publication-date')
.text(pubMonth + '/' + pubDay + '/' + pubYear);
var $summary = $('<div></div>')
.addClass('summary')
.html($('description', this).text());
$('<div></div>')
.addClass('headline')
.append($headline, $publication)
.appendTo($container);
});
var currentHeadline = 0, oldHeadline = 0;
var hiddenPosition = $container.height() + 10;
$('div.headline').eq(currentHeadline).css('top', 0);
var headlineCount = $('div.headline').length;
var pause;
var headlineRotate = function() {
currentHeadline = (oldHeadline + 1) % headlineCount;
$('div.headline').eq(oldHeadline).animate(
{top: -hiddenPosition}, 'slow', function() {
$(this).css('top', hiddenPosition);
});
$('div.headline').eq(currentHeadline).animate(
{top: 0}, 'slow', function() {
pause = setTimeout(headlineRotate, 4000);
});
oldHeadline = currentHeadline;
};
pause = setTimeout(headlineRotate, 4000);
$container.hover(function() {
clearTimeout(pause);
}, function() {
pause = setTimeout(headlineRotate, 3000);
});
});
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="sidebar">
<h3>Recent News</h3>
<div id="news-feed">
<a href="###">News Releases</a>
</div>
</div>
</form>
</body>
我們來庖丁解牛一下這些代碼,首先來看樣式,因為我們一次只顯示一條新聞記錄,所以,我們應該把高度也設為一條記錄的,在這里設為200px, 而且如果超了的話,我們就自動隱藏起來overflow=hidden。在這里,數(shù)據(jù)源我們用的是feed.xml,Jquery加載并讀取xml文件是 很簡單的,可以參考上面的寫法,通過讀取xml文件,取出數(shù)據(jù),進行組裝,就得到了要顯示的html代碼段并附加到#container中,同時,在滾動 顯示中,我們需要設置兩個變量,一個用于記錄當前可見的標題,另一個用于記錄剛剛滾動出視圖的標題。并且讓當前的記錄顯示在最上方,一定要注意的是,位置 不能為static。最后,就是寫一個函數(shù),每次自動調(diào)用記錄的顯示。jquery還有很多的插件,可以更加簡化這些操作,以后多學習了。如果想學習 jquery,個人推薦jquery基礎教程,jonathan chaffer編寫的,很不錯,很適合初學者,國內(nèi)其他的人寫的,里面就魚龍混雜了。
先粘貼一下代碼,
復制代碼 代碼如下:
<style>
<%-- #news-feed
{
padding: 0;
margin: 0 0 0 10px;
position: relative;
height: 200px;
width: 17em;
overflow: hidden;
}
.headline
{
position: absolute;
height: 200px;
top: 210px;
overflow: hidden;
}--%>
</style>
<script type="text/javascript">
$(document).ready(function() {
$('#news-feed').each(function() {
var $container = $(this);
$container.empty();
$.get('feed.xml', function(data) {
$('rss item', data).each(function() {
var $link = $('<a></a>')
.attr('href', $('link', this).text())
.text($('title', this).text());
var $headline = $('<h4></h4>').append($link);
var pubDate = new Date($('pubDate', this).text());
var pubMonth = pubDate.getMonth() + 1;
var pubDay = pubDate.getDate();
var pubYear = pubDate.getFullYear();
var $publication = $('<div></div>')
.addClass('publication-date')
.text(pubMonth + '/' + pubDay + '/' + pubYear);
var $summary = $('<div></div>')
.addClass('summary')
.html($('description', this).text());
$('<div></div>')
.addClass('headline')
.append($headline, $publication)
.appendTo($container);
});
var currentHeadline = 0, oldHeadline = 0;
var hiddenPosition = $container.height() + 10;
$('div.headline').eq(currentHeadline).css('top', 0);
var headlineCount = $('div.headline').length;
var pause;
var headlineRotate = function() {
currentHeadline = (oldHeadline + 1) % headlineCount;
$('div.headline').eq(oldHeadline).animate(
{top: -hiddenPosition}, 'slow', function() {
$(this).css('top', hiddenPosition);
});
$('div.headline').eq(currentHeadline).animate(
{top: 0}, 'slow', function() {
pause = setTimeout(headlineRotate, 4000);
});
oldHeadline = currentHeadline;
};
pause = setTimeout(headlineRotate, 4000);
$container.hover(function() {
clearTimeout(pause);
}, function() {
pause = setTimeout(headlineRotate, 3000);
});
});
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="sidebar">
<h3>Recent News</h3>
<div id="news-feed">
<a href="###">News Releases</a>
</div>
</div>
</form>
</body>
我們來庖丁解牛一下這些代碼,首先來看樣式,因為我們一次只顯示一條新聞記錄,所以,我們應該把高度也設為一條記錄的,在這里設為200px, 而且如果超了的話,我們就自動隱藏起來overflow=hidden。在這里,數(shù)據(jù)源我們用的是feed.xml,Jquery加載并讀取xml文件是 很簡單的,可以參考上面的寫法,通過讀取xml文件,取出數(shù)據(jù),進行組裝,就得到了要顯示的html代碼段并附加到#container中,同時,在滾動 顯示中,我們需要設置兩個變量,一個用于記錄當前可見的標題,另一個用于記錄剛剛滾動出視圖的標題。并且讓當前的記錄顯示在最上方,一定要注意的是,位置 不能為static。最后,就是寫一個函數(shù),每次自動調(diào)用記錄的顯示。jquery還有很多的插件,可以更加簡化這些操作,以后多學習了。如果想學習 jquery,個人推薦jquery基礎教程,jonathan chaffer編寫的,很不錯,很適合初學者,國內(nèi)其他的人寫的,里面就魚龍混雜了。
您可能感興趣的文章:
- jQuery中:header選擇器用法實例
- Jquery修改頁面標題title其它JS失效的解決方法
- 讓新消息在網(wǎng)頁標題閃爍提示的jQuery代碼
- 基于jquery插件制作左右按鈕與標題文字圖片切換效果
- Jquery 設置標題的自動翻轉(zhuǎn)
- jQuery+Ajax實現(xiàn)表格數(shù)據(jù)不同列標題排序(為表格注入活力)
- Jquery創(chuàng)建層顯示標題和內(nèi)容且隨鼠標移動而移動
- 使表格的標題列可左右拉伸jquery插件封裝
- jquery實現(xiàn)點擊彈出帶標題欄的彈出層(從右上角飛入)效果
- jQuery實現(xiàn)點擊標題輸入詳細信息
- jQuery實現(xiàn)獲取h1-h6標題元素值的方法
相關(guān)文章
基于jquery的內(nèi)容循環(huán)滾動小模塊(仿新浪微博未登錄首頁滾動微博顯示)
新浪微博未登錄首頁有一個“大家正在說”的模塊,動態(tài)滾動最新發(fā)布的微博。2011-03-03JQuery WEUI Select 組件增加搜索欄示例demo
這篇文章主要介紹了JQuery WEUI Select 組件增加搜索欄示例demo,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-10-10JQuery Tips(4) 一些關(guān)于提高JQuery性能的Tips
如今咱祖國已經(jīng)崛起了..電腦的配置也是直線上升.可是js的性能問題依然不可小覷..尤其在萬惡的IE中..js引擎速度本來就慢..如果JS如果再寫不好,客戶端多開幾個窗口假死肯定是家常便飯了.廢話不說了,下面說說js性能提升的一些小Tips.2009-12-12關(guān)于html+ashx開發(fā)中幾個問題的解決方法
在跟html+ashx打交道的園友們肯定會發(fā)現(xiàn),這種模式雖然優(yōu)美,但在開發(fā)中會遇到一些難處理的地方。我也不例外,下面是自己在實際開發(fā)中總結(jié)出來的幾條經(jīng)驗,希望跟大家分享,更希望得到大家的建議和更好的解決方法!2011-07-07如何解決jQuery EasyUI 已打開Tab重新加載問題
最近在項目中遇到這樣的需求,要求實現(xiàn)點擊左側(cè)已經(jīng)打開的tab可以刷新重新加載datagrid。下面給大家分享實現(xiàn)代碼,一起看看吧2016-12-12