Jquery 設(shè)置標(biāo)題的自動(dòng)翻轉(zhuǎn)
更新時(shí)間:2009年10月03日 10:41:29 作者:
我們平時(shí)在開發(fā)web程序的時(shí)候,想把一個(gè)新聞源滾動(dòng)顯示新聞的條目的標(biāo)題及內(nèi)容摘要,而且是每次一條,有點(diǎn)類似csdn的滾動(dòng)廣告。
即一條新聞滾進(jìn)視圖之后,會(huì)暫停幾秒鐘,然后繼續(xù)向上2滾動(dòng),淡出視圖,同時(shí),下一條新聞接著滾入視圖。這次主要是用jquery來(lái)開發(fā)這個(gè)功能,里面肯定有許多不足之處,歡迎大家點(diǎn)評(píng)。
先粘貼一下代碼,
<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>
我們來(lái)庖丁解牛一下這些代碼,首先來(lái)看樣式,因?yàn)槲覀円淮沃伙@示一條新聞?dòng)涗?,所以,我們?yīng)該把高度也設(shè)為一條記錄的,在這里設(shè)為200px,而且如果超了的話,我們就自動(dòng)隱藏起來(lái)overflow=hidden。在這里,數(shù)據(jù)源我們用的是feed.xml,Jquery加載并讀取xml文件是很簡(jiǎn)單的,可以參考上面的寫法,通過(guò)讀取xml文件,取出數(shù)據(jù),進(jìn)行組裝,就得到了要顯示的html代碼段并附加到#container中,同時(shí),在滾動(dòng)顯示中,我們需要設(shè)置兩個(gè)變量,一個(gè)用于記錄當(dāng)前可見的標(biāo)題,另一個(gè)用于記錄剛剛滾動(dòng)出視圖的標(biāo)題。并且讓當(dāng)前的記錄顯示在最上方,一定要注意的是,位置不能為static。最后,就是寫一個(gè)函數(shù),每次自動(dòng)調(diào)用記錄的顯示。jquery還有很多的插件,可以更加簡(jiǎn)化這些操作,以后多學(xué)習(xí)了。如果想學(xué)習(xí)jquery,個(gè)人推薦jquery基礎(chǔ)教程,jonathan chaffer編寫的,很不錯(cuò),很適合初學(xué)者,國(guó)內(nèi)其他的人寫的,里面就魚龍混雜了。
先粘貼一下代碼,
復(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>
我們來(lái)庖丁解牛一下這些代碼,首先來(lái)看樣式,因?yàn)槲覀円淮沃伙@示一條新聞?dòng)涗?,所以,我們?yīng)該把高度也設(shè)為一條記錄的,在這里設(shè)為200px,而且如果超了的話,我們就自動(dòng)隱藏起來(lái)overflow=hidden。在這里,數(shù)據(jù)源我們用的是feed.xml,Jquery加載并讀取xml文件是很簡(jiǎn)單的,可以參考上面的寫法,通過(guò)讀取xml文件,取出數(shù)據(jù),進(jìn)行組裝,就得到了要顯示的html代碼段并附加到#container中,同時(shí),在滾動(dòng)顯示中,我們需要設(shè)置兩個(gè)變量,一個(gè)用于記錄當(dāng)前可見的標(biāo)題,另一個(gè)用于記錄剛剛滾動(dòng)出視圖的標(biāo)題。并且讓當(dāng)前的記錄顯示在最上方,一定要注意的是,位置不能為static。最后,就是寫一個(gè)函數(shù),每次自動(dòng)調(diào)用記錄的顯示。jquery還有很多的插件,可以更加簡(jiǎn)化這些操作,以后多學(xué)習(xí)了。如果想學(xué)習(xí)jquery,個(gè)人推薦jquery基礎(chǔ)教程,jonathan chaffer編寫的,很不錯(cuò),很適合初學(xué)者,國(guó)內(nèi)其他的人寫的,里面就魚龍混雜了。
您可能感興趣的文章:
- jQuery中:header選擇器用法實(shí)例
- Jquery修改頁(yè)面標(biāo)題title其它JS失效的解決方法
- 讓新消息在網(wǎng)頁(yè)標(biāo)題閃爍提示的jQuery代碼
- 基于jquery插件制作左右按鈕與標(biāo)題文字圖片切換效果
- jQuery+Ajax實(shí)現(xiàn)表格數(shù)據(jù)不同列標(biāo)題排序(為表格注入活力)
- Jquery創(chuàng)建層顯示標(biāo)題和內(nèi)容且隨鼠標(biāo)移動(dòng)而移動(dòng)
- jQuery 標(biāo)題的自動(dòng)翻轉(zhuǎn)實(shí)現(xiàn)代碼
- 使表格的標(biāo)題列可左右拉伸jquery插件封裝
- jquery實(shí)現(xiàn)點(diǎn)擊彈出帶標(biāo)題欄的彈出層(從右上角飛入)效果
- jQuery實(shí)現(xiàn)點(diǎn)擊標(biāo)題輸入詳細(xì)信息
- jQuery實(shí)現(xiàn)獲取h1-h6標(biāo)題元素值的方法
相關(guān)文章
jquery下利用jsonp跨域訪問實(shí)現(xiàn)方法
客戶端的跨域訪問,可以通過(guò)jsonp方式來(lái)實(shí)現(xiàn),jquery提供了跨域訪問的方法,jQuery.ajax()支持get方式的跨域。當(dāng)然支持跨域還需要服務(wù)器端相應(yīng)的處理。2010-07-07
jQuery實(shí)現(xiàn)為動(dòng)態(tài)添加的元素綁定事件實(shí)例分析
這篇文章主要介紹了jQuery實(shí)現(xiàn)為動(dòng)態(tài)添加的元素綁定事件,結(jié)合實(shí)例形式分析了jQuery常見的事件綁定相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-09-09
jQuery 實(shí)現(xiàn)圖片的依次加載圖片功能
本文分為css和js代碼兩部分給大家詳細(xì)介紹了jQuery 實(shí)現(xiàn)圖片的依次加載圖片功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-07-07
省市區(qū)三級(jí)聯(lián)動(dòng)jquery實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)紹了省市區(qū)三級(jí)聯(lián)動(dòng)jquery實(shí)現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
jQuery中借助deferred來(lái)請(qǐng)求及判斷AJAX加載的實(shí)例講解
deferred對(duì)象的延遲功能對(duì)jQuery的ajax操作是一個(gè)很大的幫助,尤其是回調(diào)控制,下面我們就來(lái)看一下對(duì)jQuery中借助deferred來(lái)請(qǐng)求及判斷AJAX加載的實(shí)例講解2016-05-05
jquery實(shí)現(xiàn)頁(yè)面關(guān)鍵詞高亮顯示的方法
這篇文章主要介紹了jquery實(shí)現(xiàn)頁(yè)面關(guān)鍵詞高亮顯示的方法,實(shí)例分析了jQuery插件highlight實(shí)現(xiàn)高亮顯示的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
jQuery鼠標(biāo)經(jīng)過(guò)方形圖片切換成圓邊效果代碼分享
這篇文章主要介紹了jQuery鼠標(biāo)經(jīng)過(guò)方形圖片切換成圓邊特效,圖片可以自行替換,推薦給大家,有需要的小伙伴可以參考下。2015-08-08

