国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

來自騰訊的一個不固定高度得消息的滾動特效

2019-11-21 00:16:10
字體:
來源:轉載
供稿:網友

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]

看關鍵的js code:
復制代碼 代碼如下:

var $ = function (d){
typeof d == "string" &&(d = document.getElementById(d));
return $.fn.call(d);
};
$.fn = function (){
this.addEvent = function (sEventType,fnHandler){
if (this.addEventListener) {this.addEventListener(sEventType, fnHandler, false);}
else if (this.attachEvent) {this.attachEvent("on" + sEventType, fnHandler);}
else {this["on" + sEventType] = fnHandler;}
}
this.removeEvent = function (sEventType,fnHandler){
if (this.removeEventListener) {this.removeEventListener(sEventType, fnHandler, false);}
else if (this.detachEvent) {this.detachEvent("on" + sEventType, fnHandler);}
else { this["on" + sEventType] = null;}
}
return this;
};
var Class = {create: function() {return function() { this.initialize.apply(this, arguments); }}};
var Bind = function (obj,fun,arr){return function() {return fun.apply(obj,arr);}}
var Marquee = Class.create();
Marquee.prototype = {
initialize: function(id,name,out,speed) {
this.name = name;
this.box = $(id);
this.out = 3;//滾動間隔時間,單位秒
this.speed = speed;
this.d = 1;
this.box.style.position = "relative";
this.box.scrollTop = 0;
var _li = this.box.firstChild;
while(typeof(_li.tagName)=="undefined")_li = _li.nextSibling;
this.lis = this.box.getElementsByTagName(_li.tagName);
this.len = this.lis.length;
for(var i=0;i<this.lis.length;i++){
var __li = document.createElement(_li.tagName);
__li.innerHTML = this.lis[i].innerHTML;
this.box.appendChild(__li);//cloneNode
if(this.lis[i].offsetTop>=this.box.offsetHeight)break;
}
this.Start();
this.box.addEvent("mouseover",Bind(this,function(){clearTimeout(this.timeout);},[]));
this.box.addEvent("mouseout",Bind(this,this.Start,[]));
},
Start:function (){
clearTimeout(this.timeout);
this.timeout = setTimeout(this.name+".Up()",this.out*1000)
},
Up:function(){
clearInterval(this.interval);
this.interval = setInterval(this.name+".Fun()",10);
},
Fun:function (){
this.box.scrollTop+=this.speed;
if(this.lis[this.d].offsetTop <= this.box.scrollTop){
clearInterval(this.interval);
this.box.scrollTop = this.lis[this.d].offsetTop;
this.Start();
this.d++;
}
if(this.d >= this.len + 1){
this.d = 1;
this.box.scrollTop = 0;
}
}
};
$(window).addEvent("load",function (){
marquee = new Marquee("msg_weibo","marquee",1,2);
});

實現思路與以前的文字滾動是一樣的,都是先充滿當前容器,再通過scrollTop++往上滾的,只不過他是每次滾動的距離不是固定的,是取當前滾動消息的高度。由于scrollTop(滾出當前可視區域的高度)和offsetTop(距離父節點頂部的距離,常用于取某元素在頁面的坐標位置)的區別,所以通過 if(this.lis[this.d].offsetTop <= this.box.scrollTop)來判斷是否滾動完上條消息,需要停頓下了。

我覺得亮點之處在于$的寫法。通常Prototype里也就取下obj||document.getElementById('objId'),他這里除此外還幫obj綁定了一些方法。他的作用是不是類似于原型擴展String、Array等對象的方法呢。這個可以借鑒。
另外,他初始化時填充容器時用document.createElement->賦innerHTML->appendChild來做,我覺的不如直接cloneNode(true)->appendChild好,如不對,歡迎指正。

主要還是填下這個月的坑,哈哈。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广宁县| 临泉县| 区。| 商丘市| 浏阳市| 双城市| 汶上县| 南雄市| 浦北县| 高阳县| 衢州市| 玛曲县| 油尖旺区| 涞源县| 山东省| 二连浩特市| 呈贡县| 新化县| 双鸭山市| 巴彦淖尔市| 古蔺县| 辽中县| 漯河市| 陕西省| 阿鲁科尔沁旗| 保山市| 玛沁县| 肃南| 明星| 历史| 曲阳县| 志丹县| 思茅市| 仙桃市| 托克逊县| 洪雅县| 洛扎县| 阳高县| 河间市| 河池市| 白水县|