解决自定义$(id)的方法与jquery选择器冲突的问题

先上代码:

var $= function (id) { 
return "string" == typeof id ? document.getElementById(id) : id; 
}; 


这段代码是模仿jquery自定义id选择器的方法,但是因为jquery选择器也是用的这个“$”,如果你引用jquery并且使用这个方法,那么页面就会报错,解决大办法就是修改自己的方法把"$"改成"getId(id)";

ar getId = function (id) { 
return "string" == typeof id ? document.getElementById(id) : id; 
}; 


------------------------------------------------------分隔线----------------------------------------------------------------

在这里上一段无缝滚动文字的脚本,可以用以丰富我们的App库,实现我们App强大丰富的构想:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1- 
transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>滚动字幕代码_无缝水平滚动</title> 
</head> 
<body> 
<SCRIPT type=text/javascript> 
var $ = function (id) { 
return "string" == typeof id ? document.getElementById(id) : id; 
}; 
var Class = { 
create: function() { 
return function() { 
this.initialize.apply(this, arguments); 
} 
} 
} 
Object.extend = function(destination, source) { 
for (var property in source) { 
destination[property] = source[property]; 
} 
return destination; 
} 
function addEventHandler(oTarget, sEventType, fnHandler) { 
if (oTarget.addEventListener) { 
oTarget.addEventListener(sEventType, fnHandler, false); 
} else if (oTarget.attachEvent) { 
oTarget.attachEvent("on" + sEventType, fnHandler); 
} else { 
oTarget["on" + sEventType] = fnHandler; 
} 
}; 
var Scroller = Class.create(); 
Scroller.prototype = { 
initialize: function(idScroller, idScrollMid, options) { 
var oThis = this, oScroller = $(idScroller), oScrollMid = $(idScrollMid); 
this.SetOptions(options); 
this.Side = this.options.Side || ["up"];//方向 
this.scroller = oScroller; //对象 
this.speed = this.options.Speed; //速度 
this.timer = null; //时间 
this.pauseHeight = 0; //定高 
this.pauseWidth = 0; //定宽 
this.pause = 0; //定高(宽) 
this.side = 0; //参数 
//用于上下滚动 
this.heightScroller = parseInt(oScroller.style.height) || oScroller.offsetHeight; 
this.heightList = oScrollMid.offsetHeight; 
//用于左右滚动 
this.widthScroller = parseInt(oScroller.style.width) || oScroller.offsetWidth; 
this.widthList = oScrollMid.offsetWidth; 
//js取不到css设置的height和width 
oScroller.style.overflow = "hidden"; 
oScrollMid.appendChild(oScrollMid.cloneNode(true)); 
oScrollMid.appendChild(oScrollMid.cloneNode(true)); 
addEventHandler(oScroller, "mouseover", function() { oThis.Stop(); }); 
addEventHandler(oScroller, "mouseout", function() { oThis.Start(); }); 
this.Start(); 
}, 
//设置默认属性 
SetOptions: function(options) { 
this.options = {//默认值 
Step: 1,//每次变化的px量 
Speed: 20,//速度(越大越慢) 
Side: ["up"],//滚动方向:"up"是上,"down"是下,"left"是左,"right"是右 
PauseHeight: 0,//隔多高停一次 
PauseWidth: 0,//隔多宽停一次 
//当上下和左右一起使用时必须设置PauseHeight和PauseWidth来设置转向位置 
PauseStep: 3000//停顿时间(PauseHeight或PauseWidth大于0该参数才有效) 
}; 
Object.extend(this.options, options || {}); 
}, 
//转向 
Turn: function() { 
//通过设置方向数组的排列来转向 
this.Side.push(this.Side.shift().toLowerCase()); 
}, 
//上下滚动 
ScrollUpDown: function() { 
this.pause = this.pauseHeight; 
this.scroller.scrollTop = this.GetScroll(this.scroller.scrollTop, this.heightScroller, this.heightList, 
this.options.PauseHeight); 
this.pauseHeight = this.pause; 
var oThis = this; 
this.timer = window.setTimeout(function(){ oThis.Start(); }, this.speed); 
}, 
//左右滚动 
ScrollLeftRight: function() { 
this.pause = this.pauseWidth; 
//注意:scrollLeft超过1400会自动变回1400 注意长度 
this.scroller.scrollLeft = this.GetScroll(this.scroller.scrollLeft, this.widthScroller, this.widthList, 
this.options.PauseWidth); 
this.pauseWidth = this.pause; 
var oThis = this; 
this.timer = window.setTimeout(function(){ oThis.Start(); }, this.speed); 
}, 
//获取设置滚动数据 
GetScroll: function(iScroll, iScroller, iList, iPause) { 
var iStep = this.options.Step * this.side; 
if(this.side > 0){ 
if(iScroll >= (iList * 2 - iScroller)){ iScroll -= iList; } 
} else { 
if(iScroll <= 0){ iScroll += iList; } 
} 
this.speed = this.options.Speed; 
if(iPause > 0){ 
if(Math.abs(this.pause) >= iPause){ 
this.speed = this.options.PauseStep; this.pause = iStep = 0; this.Turn(); 
} else { 
this.pause += iStep; 
} 
} 
return (iScroll + iStep); 
}, 
//开始 
Start: function() { 
//document.getElementById("test").innerHTML+=sTurn+","; 
//方向设置 
switch (this.Side[0].toLowerCase()) { 
case "right" : 
if(this.widthList < this.widthScroller) return; 
this.side = -1; 
this.ScrollLeftRight(); 
break; 
case "left" : 
if(this.widthList < this.widthScroller) return; 
this.side = 1; 
this.ScrollLeftRight(); 
break; 
case "down" : 
if(this.heightList < this.heightScroller) return; 
this.side = -1; 
this.ScrollUpDown(); 
break; 
case "up" : 
default : 
if(this.heightList < this.heightScroller) return; 
this.side = 1; 
this.ScrollUpDown(); 
} 
}, 
//停止 
Stop: function() { 
clearTimeout(this.timer); 
} 
}; 
</SCRIPT> 
<STYLE> 
body {font-size:12px;} 
.Scroller {line-height:20px; border:1px solid #D4D4D4; padding:0px 10px; height:20px; width:400px;} 
.Scroller *{margin:0px; padding:0px;} 
.ScrollMid {float:left;} 
.ScrollMid ul{width:800px;float:left;} 
.ScrollMid li{list-style:none; float:left; width:390px; padding-left:10px;line-height:20px; } 
</STYLE> 
<DIV class=Scroller id=idScroller> 
<DIV style="WIDTH: 1600px"> 
<DIV class=ScrollMid id=idScrollMid> 
<UL> 
<LI><a href="http://www.51xuediannao.com" target="_blank">网页特效,原创建站视频和CSS技巧。</a></LI> 
<LI><a href="http://www.51xuediannao.com" target="_blank">JS代码,js特效代码大全,jquery特效,导航菜单代码,焦点幻灯片
</a></LI> 
<LI><a href="http://www.51xuediannao.com" target="_blank">网页特效,原创建站视频和CSS技巧。 
</a></LI> 
<LI><a href="http://www.51xuediannao.com" target="_blank">JS代码,js特效代码大全,jquery特效,导航菜单代码,焦点幻灯片
</a></LI></UL></DIV></DIV></DIV> 
<SCRIPT> 
new Scroller("idScroller", "idScrollMid",{ Side:["up","left"], PauseHeight:20, PauseWidth:400 }); 
</SCRIPT> 

</body> 

</div>

</html>


					



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lixp3

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值