Jquery數(shù)字上下滾動(dòng)動(dòng)態(tài)切換插件
Jq打造的數(shù)字滾動(dòng)插件,數(shù)字變化時(shí),動(dòng)態(tài)滾動(dòng)切換,效果非常好。
我們先來(lái)看示例:
CSS
.textC {
position:absolute;
width:500px;
overflow:hidden;
margin-top: 100px;
line-height:30px;
margin-left: 300px;
height:30px;
}
.textC span {
color: #13BEEC;
font-size: 28px;
font-weight: bold;
font-family: Georgia, "Times New Roman", Times, serif;
position: absolute;
}
HTML
<p style="text-align:center;"><a style="float:left; margin-left:300px; margin-top:200px;" href="javascript:void(0);" onClick="NumbersAnimate.ChangeNumber(NumbersAnimate.RandomNum(10000000,19999999));">隨機(jī)切換數(shù)字</a>
</p>
JS
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<script type="text/javascript">
$(function(){
NumbersAnimate.Target=$(".textC");
NumbersAnimate.Numbers=12389623;
NumbersAnimate.Duration=1500;
NumbersAnimate.Animate();
});
var NumbersAnimate={
Target:null,
Numbers:0,
Duration:500,
Animate:function(){
var array=NumbersAnimate.Numbers.toString().split("");
//遍歷數(shù)組
for(var i=0;i<array.length;i++){
var currentN=array[i];
//數(shù)字append進(jìn)容器
var t=$("<span></span>");
$(t).append("<span class=\"childNumber\">"+array[i]+"</span>");
$(t).css("margin-left",18*i+"px");
$(NumbersAnimate.Target).append(t);
//生成滾動(dòng)數(shù)字,根據(jù)當(dāng)前數(shù)字大小來(lái)定
for(var j=0;j<=currentN;j++){
var tt;
if(j==currentN){
tt=$("<span class=\"main\"><span>"+j+"</span></span>");
}else{
tt=$("<span class=\"childNumber\">"+j+"</span>");
}
$(t).append(tt);
$(tt).css("margin-top",(j+1)*25+"px");
}
$(t).animate({marginTop:-((parseInt(currentN)+1)*25)+"px"},NumbersAnimate.Duration,function(){
$(this).find(".childNumber").remove();
});
}
},
ChangeNumber:function(numbers){
var oldArray=NumbersAnimate.Numbers.toString().split("");
var newArray=numbers.toString().split("");
for(var i=0;i<oldArray.length;i++){
var o=oldArray[i];
var n=newArray[i];
if(o!=n){
var c=$($(".main")[i]);
var num=parseInt($(c).html());
var top=parseInt($($(c).find("span")[0]).css("marginTop").replace('px', ''));
for(var j=0;j<=n;j++){
var nn=$("<span>"+j+"</span>");
if(j==n){
nn=$("<span>"+j+"</span>");
}else{
nn=$("<span class=\"yy\">"+j+"</span>");
}
$(c).append(nn);
$(nn).css("margin-top",(j+1)*25+top+"px");
}
var margintop=parseInt($(c).css("marginTop").replace('px', ''));
$(c).animate({marginTop:-((parseInt(n)+1)*25)+margintop+"px"},NumbersAnimate.Duration,function(){
$($(this).find("span")[0]).remove();
$(".yy").remove();
});
}
}
NumbersAnimate.Numbers=numbers;
},
RandomNum:function(m,a){
var Range = a - m;
var Rand = Math.random();
return(m + Math.round(Rand * Range));
}
}
</script>
插件使用非常簡(jiǎn)單
1. 第一次調(diào)用時(shí)
NumbersAnimate.Target=$(".textC");
NumbersAnimate.Numbers=12389623;
NumbersAnimate.Duration=1500;
NumbersAnimate.Animate();
2. 如果數(shù)字改變了,再次調(diào)用就只需要調(diào)用Change函數(shù)即可
NumbersAnimate.ChangeNumber();
該插件有3個(gè)參數(shù),分別是:
Target:數(shù)字的父級(jí)容器
Numbers:顯示的數(shù)字
Duration:滾動(dòng)速度,單位是毫秒
使用注意:當(dāng)數(shù)字改變后調(diào)用Change方法時(shí),需要保證改變后的數(shù)字和之前的數(shù)字位數(shù)一致。
相關(guān)文章
40個(gè)有創(chuàng)意的jQuery圖片和內(nèi)容滑動(dòng)及彈出插件收藏集之二
在網(wǎng)頁(yè)的首頁(yè)或圖片專(zhuān)題頁(yè)面很多地方都會(huì)用到圖片滑動(dòng)插件來(lái)循環(huán)切換多張圖片,并且用戶(hù)可以點(diǎn)擊左右按鈕來(lái)切換圖片。2011-12-12
jQuery EasyUI 菜單與按鈕之創(chuàng)建簡(jiǎn)單的菜單和鏈接按鈕
這篇文章主要介紹了jQuery EasyUI 菜單與按鈕之創(chuàng)建簡(jiǎn)單的菜單和鏈接按鈕,需要的朋友可以參考下2015-11-11
jQuery 1.9.1源碼分析系列(十)事件系統(tǒng)之主動(dòng)觸發(fā)事件和模擬冒泡處理
這篇文章主要介紹了jQuery 1.9.1源碼分析系列(十)事件系統(tǒng)之主動(dòng)觸發(fā)事件和模擬冒泡處理的相關(guān)資料,需要的朋友可以參考下2015-11-11
jQuery獲取訪(fǎng)問(wèn)者IP地址的方法(基于新浪API與QQ查詢(xún)接口)
這篇文章主要介紹了jQuery獲取訪(fǎng)問(wèn)者IP地址的方法,實(shí)例分析了jQuery基于新浪API與QQ查詢(xún)接口獲取來(lái)訪(fǎng)者IP的相關(guān)參數(shù)傳遞與數(shù)據(jù)處理技巧,需要的朋友可以參考下2016-05-05

