原生js實現(xiàn)公告滾動效果
本文實例為大家分享了js實現(xiàn)公告滾動展示的具體代碼,供大家參考,具體內(nèi)容如下
1.html結(jié)構(gòu)
<body> <div id="notice" class="notice"> <ul id="noticeList"> <li>我是公告1</li> <li>我是公告2</li> <li>我是公告3</li> <li>我是公告4</li> </ul> </div> </body>
2.css樣式
<style type="text/css">
body,
div,
ul,
li {
margin: 0;
padding: 0;
}
ul,
li {
list-style: none;
}
.notice {
width: 300px;
height: 30px;
border: 1px solid black;
text-align: center;
overflow: hidden;
}
li {
padding: 3px;
}
</style>
3.js行為
<script type="text/javascript">
window.onload = function() {
var notice = document.getElementById("notice");
var noticeList = document.getElementById("noticeList");
// 獲取ul下第一個li元素,好計算li的高度,因為后面滾動的時候每次要滾動一個高度,這里li都是一樣高的,
// 所以獲取第一個的高度就行了,不然要遍歷獲取每一個li的高度。
var noticeFirstItem = noticeList.querySelector("li");
// 獲取li的高度,這里獲取的是offsetHeight,關(guān)于js各種高度的定義可以注意以下
var scrollHeight = noticeFirstItem.offsetHeight;
// 是否可以進行動畫
var opt = {
animated: true,
interval: 1000
};
notice.onclick = function() {
// 動畫之前首先重置
// noticeFirstItem.style.transition = "";
noticeFirstItem.style.marginTop = 0;
if (opt.animated) {
opt.animated = false;
animate(noticeList, scrollHeight, opt);
}
};
};
// 動畫函數(shù),obj——要產(chǎn)生動畫的對象,sHeight——每次要滾動的距離,interval——多久滾動一次
function animate(obj, sHeight, option) {
// 當滾到最后一條公告的時候就不用動畫了。
var stopHeight = sHeight - obj.scrollHeight;
var marginTopNum = 0;
var timer = setInterval(function() {
marginTopNum -= sHeight;
obj.style.marginTop = marginTopNum + "px";
obj.style.transition = "margin-top 1.5s ease";
// 注意這里的比較符號,前面得到的高度都進行四舍五入了
if (marginTopNum <= stopHeight) {
clearInterval(timer);
// option.animated = true;
}
}, option.interval);
}
</script>
4.運行結(jié)果

動畫在進行中時注意控制不能進行其他動畫!
結(jié)束語:不要把動畫想得很難,當你想實現(xiàn)復(fù)雜的動畫時,比如jquery的animate方法,你可以先實現(xiàn)針對一個屬性的動畫,然后再想辦法擴展到多個屬性(即以對象方式去傳參,然后遍歷對象中的每個樣式屬性,然后給每個樣式屬性添加動畫)。以前都是用js去實現(xiàn)每一幀每一幀的移動,即在肉眼無法反應(yīng)過來的時間里產(chǎn)生移動,這樣就能產(chǎn)生連續(xù)移動的效果,現(xiàn)在css3出來了,可以方便的利用css3來實現(xiàn)過渡效果了,而不用復(fù)雜的js來實現(xiàn)了。這個真的太棒了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript?進階問題列表(各種js代碼段108-155)
從基礎(chǔ)到進階,測試你有多了解?JavaScript,刷新你的知識,或者幫助你的?coding?面試!?:muscle:?:rocket:?我每周都會在這個倉庫下更新新的問題2024-11-11
JavaScript正則表達式小結(jié)(test|match|search|replace|split|exec)
這篇文章主要介紹了JavaScript正則表達式小結(jié)(test|match|search|replace|split|exec)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2016-12-12
Bootstrap 模態(tài)框多次顯示后臺提交多次BUG的解決方法
本篇文章主要介紹了Bootstrap 模態(tài)框多次顯示后臺提交多次BUG的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12

