MSN频道4屏新闻广告效果轮播滚动切换特效代码

版权:原创 更新时间:1年以上
[该文章底部包含文件资源,可根据自己情况,决定是否下载资源使用,时间>金钱,如有需要,立即查看资源]

以下是 MSN频道4屏新闻广告效果轮播滚动切换特效代码 的示例演示效果:

当前平台(PC电脑)
  • 平台:

部分效果截图:

MSN频道4屏新闻广告效果轮播滚动切换特效代码

HTML代码(index.html):

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2242">
<meta name="keywords" content="JS代码,焦点图,JS广告代码,JS特效代码" />
<meta name="description" content="此代码内容为MSN频道4屏新闻广告效果" />
<title>MSN频道4屏新闻广告效果</title>
<link href="css/css.css" rel="stylesheet" type="text/css">
<SCRIPT src="js/slideframework.js" type=text/javascript></SCRIPT>
</head>
<body><div align="center">
<DIV class=kuan460>
<DIV>
<DIV id=Carousel>
<!-- 1 slide -->
<DIV class="slide dark"><IMG class=bg 
style="FILTER: ; WIDTH: 460px; HEIGHT: 200px" height=200 alt="" hspace=0 
src="images/b-01.jpg" width=460 border=0> 
<DIV class=frame>
<DIV class=text>
<H1><A 
href="#">雅虎中国重启Yisou.com?</A></H1>周鸿祎获表示:“这说明雅虎中国再次认同独立搜索品牌的运作。”不过,在目前百度一家独大的情况下,再次酝酿独立的搜索品牌成功率不高。</B></A></DIV>
<DIV class="image screen"></DIV></DIV></DIV>
<!-- 2 slide -->
<DIV class="slide dark"><IMG class=bg 
style="FILTER: ; WIDTH: 460px; HEIGHT: 200px" height=200 alt="" hspace=0 
src="images/b-02.jpg" width=460 border=0> 
<DIV class=frame>
<DIV class=text>
<H1><A 
href="#">叛将密谋颠覆暴雪王朝</A></H1>我在心中一直梦想着亚洲。我拥有50%的中国血统,也曾在中国度过我的童年。我很想为中国的发展出一份力。<BR>
<LI><A href="#">·RED 
5的皮克斯梦想</A></B></A></LI></DIV>
<DIV class="image screen"></DIV></DIV></DIV>
<!-- 3 slide -->
<DIV class="slide light"><IMG class=bg src="images/b-03.jpg"> 
<DIV class=frame>
<DIV class=text>
<H1><A 
href="#">曾经中国网络概念第一股今何在?</A></H1>CDC门户是曾经号称中国概念第一股的中华网,什么原因让这个曾经的“巨人”没落?</A><BR><A 
href="#"><B>·中华网投资集团Q4净亏损420万美元</B></A></DIV>
<DIV class="image screen"></DIV></DIV></DIV>
<!-- 4 slide -->
<DIV class="slide dark"><IMG class=bg 
style="FILTER: ; WIDTH: 460px; HEIGHT: 200px" height=200 alt="" hspace=0 
src="images/b-04.jpg" width=460 border=0> 
<DIV class=frame>
<DIV class=text>
<H1><A 
href="#">低价手机让MOTO走上悬崖?</A></H1>低价手机曾让摩托罗拉尝到过甜头,但是,这把双刃剑同时也伤了MOTO,利润的捉襟见肘使得他们必须调整策略。</A></DIV>
<DIV class="image screen"></DIV></DIV></DIV>

<DIV id=CaroLinks>
<!-- 1 button -->
<DIV class=bubble><IMG class=bbg src="……" width=221> <A 
href="#"><IMG 
src="images/s-01.gif" width=35 border=0><SPAN>雅虎中国重启Yisou 
<FONT style="FONT-SIZE: 10px" color=red>Update</FONT></SPAN></A> </DIV>
<!-- 2 button -->
<DIV class=bubble><IMG class=bbg src="……" width=221> <A 
href="#"><IMG 
style="FILTER: ; WIDTH: 35px; HEIGHT: 26px" height=26 alt="" hspace=0 
src="images/s-02.gif" width=35 border=0> <SPAN>叛将密谋颠覆暴雪<FONT 
style="FONT-SIZE: 10px" color=red>Update</FONT></SPAN></A></DIV>
<!-- 3 button -->
<DIV class=bubble><IMG class=bbg src="……" width=221> <A 
href="#"><IMG height=26 
src="images/s-03.gif" width=35 
border=0><SPAN>CDC的前世今生</SPAN></A></DIV>
<!-- 4 button -->
<DIV class=bubble><IMG class=bbg src="……" width=221> <A 
href="#"><IMG 
style="FILTER: ; WIDTH: 35px; HEIGHT: 26px" height=26 alt="" hspace=0 
src="images/s-04.gif" width=35 border=0><SPAN>低价毁了MOTO? 
</SPAN></A></DIV>
</DIV>
</DIV>
</DIV>
</DIV>
</DIV>
<p align="center"></p>
<p align="center"></p>
<p align="center"></p>
</body>
</html>

JS代码(slideframework.js):

dbug={
	logged:[],timers:{
}
,firebug:false,debug:false,log:function(){
	dbug.logged.push(arguments)}
,nolog:function(msg){
	dbug.logged.push(arguments)}
,time:function(name){
	dbug.timers[name]=new Date().getTime()}
,timeEnd:function(name){
	if(dbug.timers[name]){
	var end=new Date().getTime()-dbug.timers[name];
	dbug.timers[name]=false;
	dbug.log('%s:%s',name,end)}
else dbug.log('no such timer:%s',name)}
,enable:function(){
	if(dbug.firebug){
	try{
	dbug.debug=true;
	dbug.log=console.debug||console.log;
	dbug.time=console.time;
	dbug.timeEnd=console.timeEnd;
	dbug.log('enabling dbug');
	for(i=0;
	i<dbug.logged.length;
	i++){
	dbug.log.apply(console,dbug.logged[i])}
dbug.logged=[]}
catch(e){
	dbug.enable.delay(400)}
}
}
,disable:function(){
	if(dbug.firebug)dbug.debug=false;
	dbug.log=dbug.nolog;
	dbug.time=function(){
}
;
	dbug.timeEnd=function(){
}
}
,cookie:function(){
	dbug.log('setting debugging cookie');
	var date=new Date();
	date.setTime(date.getTime()+(24*60*60*1000));
	document.cookie='jsdebug=true;
	expires='+date.toGMTString()}
,disableCookie:function(){
	dbug.log('disabling debugging cookie');
	document.cookie='jsdebug=false'}
,loadtime:function(){
}
,loadtimeEnd:function(){
}
}
;
	if(typeof console!="undefined"&&console.warn){
	dbug.firebug=true;
	var value=document.cookie.match('(?:^|;
	)\\s*jsdebug=([^;
	]*)');
	var debugCookie=value?unescape(value[1]):false;
	if(window.location.href.indexOf("jsdebug=true")>0||debugCookie=='true')dbug.enable();
	if(debugCookie=='true')dbug.log('debugging cookie enabled');
	if(window.location.href.indexOf("jsdebugCookie=true")>0){
	dbug.cookie();
	if(!dbug.debug)dbug.enable()}
if(window.location.href.indexOf("jsdebugCookie=false")>0)dbug.disableCookie()}
var Class=function(properties){
	var klass=function(){
	if(this.initialize&&$type(this.initialize)=='function')return this.initialize.apply(this,arguments);
	else return this}
;
	$extend(klass,this);
	klass.prototype=properties;
	return klass}
;
	Class.empty=function(){
}
;
	Class.prototype={
	extend:function(properties){
	var proto=$merge(this.prototype);
	for(var property in properties){
	var pp=proto[property];
	proto[property]=$mergeClass(pp,properties[property])}
return new Class(proto)}
,implement:function(properties){
	$extend(this.prototype,properties)}
}
;
	function $type(obj){
	if(obj===null||obj===undefined)return false;
	var type=typeof obj;
	if(type=='object'){
	if(obj.htmlElement)return'element';
	if(obj.push)return'array';
	if(obj.nodeName){
	switch(obj.nodeType){
	case 1:return'element';
	case 3:return obj.nodeValue.test(/\S/)?'textnode':'whitespace'}
}
}
return type}
;
	function $merge(){
	var mix={
}
;
	for(var i=0;
	i<arguments.length;
	i++){
	for(var property in arguments[i]){
	var ap=arguments[i][property];
	var mp=mix[property];
	if(mp&&$type(ap)=='object'&&$type(mp)=='object')mix[property]=$merge(mp,ap);
	else mix[property]=ap}
}
return mix}
;
	function $mergeClass(previous,current){
	if(previous&&previous!=current){
	var ptype=$type(previous);
	var ctype=$type(current);
	if(ptype=='function'&&ctype=='function'){
	return function(){
	this.parent=previous;
	return current.apply(this,arguments)}
}
if(ptype=='object'&&ctype=='object')return $merge(previous,current)}
return current}
;
	var $extend=Object.extend=function(){
	var args=arguments;
	if(!args[1])args=[this,args[0]];
	for(var property in args[1])args[0][property]=args[1][property];
	return args[0]}
;
	var $native=Object.Native=function(){
	for(var i=0;
	i<arguments.length;
	i++)arguments[i].extend=$native.extend}
;
	$native.extend=function(props){
	for(var prop in props){
	if(!this.prototype[prop])this.prototype[prop]=props[prop]}
}
;
	$native(Function,Array,String,Number,Class);
	window.extend=document.extend=$extend;
	var Window=window;
	function $chk(obj){
	return!!(obj||obj===0)}
;
	function $pick(obj,picked){
	return($type(obj))?obj:picked}
;
	function $random(min,max){
	return Math.floor(Math.random()*(max-min+1)+min)}
;
	function $time(){
	return new Date().getTime()}
;
	function $clear(timer){
	clearTimeout(timer);
	clearInterval(timer);
	return null}
;
	if(window.ActiveXObject)window.ie=window[window.XMLHttpRequest?'ie7':'ie6']=true;
	else if(document.childNodes&&!document.all&&!navigator.taintEnabled)window.khtml=true;
	else if(document.getBoxObjectFor!=null)window.gecko=true;
	if(typeof HTMLElement=='undefined'){
	var HTMLElement=Class.empty;
	if(window.khtml)document.createElement("iframe");
	HTMLElement.prototype=(window.khtml)?window["[[DOMElement.prototype]]"]:{
}
}
HTMLElement.prototype.htmlElement=true;
	if(window.ie6)try{
	document.execCommand("BackgroundImageCache",false,true)}
catch(e){
}
;
	Array.extend({
	forEach:function(fn,bind){
	for(var i=0,j=this.length;
	i<j;
	i++)fn.call(bind,this[i],i,this)}
,filter:function(fn,bind){
	var results=[];
	for(var i=0,j=this.length;
	i<j;
	i++){
	if(fn.call(bind,this[i],i,this))results.push(this[i])}
return results}
,map:function(fn,bind){
	var results=[];
	for(var i=0,j=this.length;
	i<j;
	i++)results[i]=fn.call(bind,this[i],i,this);
	return results}
,every:function(fn,bind){
	for(var i=0,j=this.length;
	i<j;
	i++){
	if(!fn.call(bind,this[i],i,this))return false}
return true}
,some:function(fn,bind){
	for(var i=0,j=this.length;
	i<j;
	i++){
	if(fn.call(bind,this[i],i,this))return true}
return false}
,indexOf:function(item,from){
	from=from||0;
	var len=this.length;
	if(from<0)from=Math.max(0,len+from);
	while(from<len){
	if(this[from]===item)return from;
	from++}
return-1}
,copy:function(start,length){
	start=start||0;
	if(start<0)start=this.length+start;
	length=length||(this.length-start);
	var newArray=[];
	for(var i=0;
	i<length;
	i++)newArray[i]=this[start++];
	return newArray}
,remove:function(item){
	var i=0;
	var len=this.length;
	while(i<len){
	if(this[i]===item)this.splice(i,1);
	else i++}
return this}
,test:function(item,from){
	return this.indexOf(item,from)!=-1}
,extend:function(newArray){
	var pos=this.length;
	for(var i=0,j=newArray.length;
	i<j;
	i++)this[pos++]=newArray[i];
	return this}
,associate:function(keys){
	var obj={
}
,length=Math.min(this.length,keys.length);
	for(var i=0;
	i<length;
	i++)obj[keys[i]]=this[i];
	return obj}
}
);
	Array.prototype.each=Array.prototype.forEach;
	function $A(array,start,length){
	return Array.prototype.copy.call(array,start,length)}
;
	function $each(iterable,fn,bind){
	if(iterable.length)Array.prototype.forEach.call(iterable,fn,bind);
	else for(var name in iterable)fn.call(bind,iterable[name],name)}
;
	String.extend({
	test:function(regex,params){
	return((typeof regex=='string')?new RegExp(regex,params):regex).test(this)}
,toInt:function(){
	return parseInt(this)}
,toFloat:function(){
	return parseFloat(this)}
,camelCase:function(){
	return this.replace(/-\D/g,function(match){
	return match.charAt(1).toUpperCase()}
)}
,hyphenate:function(){
	return this.replace(/\w[A-Z]/g,function(match){
	return(match.charAt(0)+'-'+match.charAt(1).toLowerCase())}
)}
,capitalize:function(){
	return this.toLowerCase().replace(/\b[a-z]/g,function(match){
	return match.toUpperCase()}
)}
,trim:function(){
	return this.replace(/^\s+|\s+$/g,'')}
,clean:function(){
	return this.replace(/\s{
	2,}
/g,' ').trim()}
,rgbToHex:function(array){
	var rgb=this.match(/\d{
	1,3}
/g);
	return(rgb)?rgb.rgbToHex(array):false}
,hexToRgb:function(array){
	var hex=this.match(/^#?(\w{
	1,2}
)(\w{
	1,2}
)(\w{
	1,2}
)$/);
	return(hex)?hex.slice(1).hexToRgb(array):false}
}
);
	Array.extend({
	rgbToHex:function(array){
	if(this.length<3)return false;
	if(this[3]&&(this[3]==0)&&!array)return'transparent';
	var hex=[];
	for(var i=0;
	i<3;
	i++){
	var bit=(this[i]-0).toString(16);
	hex.push((bit.length==1)?'0'+bit:bit)}
return array?hex:'#'+hex.join('')}
,hexToRgb:function(array){
	if(this.length!=3)return false;
	var rgb=[];
	for(var i=0;
	i<3;
	i++){
	rgb.push(parseInt((this[i].length==1)?this[i]+this[i]:this[i],16))}
return array?rgb:'rgb('+rgb.join(',')+')'}
}
);
	Number.extend({
	toInt:function(){
	return parseInt(this)}
,toFloat:function(){
	return parseFloat(this)}
}
);
	Function.extend({
	create:function(options){
	var fn=this;
	options=$merge({
	'bind':fn,'event':false,'arguments':null,'delay':false,'periodical':false,'attempt':false}
,options);
	if($chk(options.arguments)&&$type(options.arguments)!='array')options.arguments=[options.arguments];
	return function(event){
	var args;
	if(options.event){
	event=event||window.event;
	args=[(options.event===true)?event:new options.event(event)];
	if(options.arguments)args=args.concat(options.arguments)}
else args=options.arguments||arguments;
	var returns=function(){
	return fn.apply(options.bind,args)}
;
	if(options.delay)return setTimeout(returns,options.delay);
	if(options.periodical)return setInterval(returns,options.periodical);
	if(options.attempt){
	try{
	return returns()}
catch(err){
	return err}
}
return returns()}
}
,pass:function(args,bind){
	return this.create({
	'arguments':args,'bind':bind}
)}
,attempt:function(args,bind){
	return this.create({
	'arguments':args,'bind':bind,'attempt':true}
)()}
,bind:function(bind,args){
	return this.create({
	'bind':bind,'arguments':args}
)}
,bindAsEventListener:function(bind,args){
	return this.create({
	'bind':bind,'event':true,'arguments':args}
)}
,delay:function(ms,bind,args){
	return this.create({
	'delay':ms,'bind':bind,'arguments':args}
)()}
,periodical:function(ms,bind,args){
	return this.create({
	'periodical':ms,'bind':bind,'arguments':args}
)()}
}
);
	var Element=new Class({
	initialize:function(el,props){
	if($type(el)=='string')el=document.createElement(el);
	el=$(el);
	if(!props||!el)return el;
	for(var prop in props){
	switch(prop){
	case'styles':el.setStyles(props[prop]);
	break;
	case'events':el.addEvents(props[prop]);
	break;
	case'attributes':el.setProperties(props[prop]);
	break;
	default:el.setProperty(prop,props[prop])}
}
return el}
}
);
	function $(el){
	if(!el)return false;
	if(el.htmlElement||[window,document].test(el))return el;
	if($type(el)=='string')el=document.getElementById(el);
	if($type(el)!='element')return false;
	if(['object','embed'].test(el.tagName.toLowerCase()))return el;
	Garbage.collect(el);
	$extend(el,Element.prototype);
	el.htmlElement=true;
	return el}
;
	var Elements=new Class({
}
);
	$native(Elements);
	document.getElementsBySelector=document.getElementsByTagName;
	function $$(){
	if(!arguments)return false;
	var elements=[];
	for(var i=0,j=arguments.length;
	i<j;
	i++){
	var selector=arguments[i];
	switch($type(selector)){
	case'element':elements.push($(selector));
	break;
	case'string':selector=document.getElementsBySelector(selector,true);
	default:if(selector.length){
	for(var k=0,l=selector.length;
	k<l;
	k++){
	var el=$(selector[k]);
	if(el)elements.push(el)}
}
}
}
return $extend(elements,new Elements)}
;
	Elements.Multi=function(property){
	return function(){
	var args=arguments;
	var items=[];
	var elements=true;
	$each(this,function(el){
	var returns=el[property].apply(el,args);
	if($type(returns)!='element')elements=false;
	items.push(returns)}
);
	if(elements)items=$$(items);
	return items}
}
;
	Element.extend=function(properties){
	for(var property in properties){
	HTMLElement.prototype[property]=properties[property];
	Element.prototype[property]=properties[property];
	Elements.prototype[property]=Elements.Multi(property)}
}
;
	Element.extend({
	inject:function(el,where){
	$(el);
	switch(where){
	case"before":$(el.parentNode).insertBefore(this,el);
	break;
	case"after":if(!el.getNext())$(el.parentNode).appendChild(this);
	else $(el.parentNode).insertBefore(this,el.getNext());
	break;
	case"inside":el.appendChild(this)}
return this}
,injectBefore:function(el){
	return this.inject(el,'before')}
,injectAfter:function(el){
	return this.inject(el,'after')}
,injectInside:function(el){
	return this.inject(el,'inside')}
,adopt:function(){
	$$(arguments).each(function(el){
	this.appendChild(el)}
,this);
	return this}
,remove:function(){
	this.parentNode.removeChild(this);
	return this}
,clone:function(contents){
	var el=this.cloneNode(contents!==false);
	return $(el)}
,replaceWith:function(el){
	$(el);
	this.parentNode.replaceChild(el,this);
	return el}
,appendText:function(text){
	if(window.ie){
	switch(this.getTag()){
	case'style':this.styleSheet.cssText=text;
	return this;
	case'script':this.setProperty('text',text);
	return this}
}
this.appendChild(document.createTextNode(text));
	return this}
,hasClass:function(className){
	return this.className.test('(?:^|\\s)'+className+'(?:\\s|$)')}
,addClass:function(className){
	if(!this.hasClass(className))this.className=(this.className+' '+className).clean();
	return this}
,removeClass:function(className){
	this.className=this.className.replace(new RegExp('(^|\\s)'+className+'(?:\\s|$)'),'$1').clean();
	return this}
,toggleClass:function(className){
	return this.hasClass(className)?this.removeClass(className):this.addClass(className)}
,setStyle:function(property,value){
	switch(property){
	case'opacity':return this.setOpacity(parseFloat(value));
	case'float':property=(window.ie)?'styleFloat':'cssFloat'}
this.style[property.camelCase()]=(value.push)?'rgb('+value.join(',')+')':value;
	return this}
,setStyles:function(source){
	switch($type(source)){
	case'object':for(var property in source)this.setStyle(property,source[property]);
	break;
	case'string':this.style.cssText=source}
return this}
,setOpacity:function(opacity){
	if(opacity==0){
	if(this.style.visibility!="hidden")this.style.visibility="hidden"}
else{
	if(this.style.visibility!="visible")this.style.visibility="visible"}
if(!this.currentStyle||!this.currentStyle.hasLayout)this.style.zoom=1;
	if(window.ie)this.style.filter="alpha(opacity="+opacity*100+")";
	this.style.opacity=this.opacity=opacity;
	return this}
,getStyle:function(property){
	property=property.camelCase();
	var style=this.style[property];
	if(!$chk(style)){
	if(property=='opacity')return $chk(this.opacity)?this.opacity:1;
	if(['margin','padding'].test(property)){
	var result=[];
	['top','right','bottom','left'].each(function(prop){
	result.push(this.getStyle(property+'-'+prop)||'0')}
,this);
	var every=result.every(function(val){
	return val==result[0]}
);
	return(every)?result[0]:result}
if(document.defaultView)style=document.defaultView.getComputedStyle(this,null).getPropertyValue(property.hyphenate());
	else if(this.currentStyle)style=this.currentStyle[property]}
if(style=='auto'&&['height','width'].test(property))return this['offset'+property.capitalize()]+'px';
	return(style&&property.test(/color/i)&&style.test(/rgb/))?style.rgbToHex():style}
,getStyles:function(){
	var result={
}
;
	$each(arguments,function(argument){
	result[argument]=this.getStyle(argument)}
,this);
	return result}
,addEvent:function(type,fn){
	this.events=this.events||{
}
;
	this.events[type]=this.events[type]||{
	'keys':[],'values':[]}
;
	if(!this.events[type].keys.test(fn)){
	this.events[type].keys.push(fn);
	if(this.addEventListener){
	this.addEventListener((type=='mousewheel'&&window.gecko)?'DOMMouseScroll':type,fn,false)}
else{
	fn=fn.bind(this);
	this.attachEvent('on'+type,fn);
	this.events[type].values.push(fn)}
}
return this}
,addEvents:function(source){
	if(source){
	for(var type in source)this.addEvent(type,source[type])}
return this}
,removeEvent:function(type,fn){
	if(this.events&&this.events[type]){
	var pos=this.events[type].keys.indexOf(fn);
	if(pos==-1)return this;
	var key=this.events[type].keys.splice(pos,1)[0];
	if(this.removeEventListener){
	this.removeEventListener((type=='mousewheel'&&window.gecko)?'DOMMouseScroll':type,key,false)}
else{
	this.detachEvent('on'+type,this.events[type].values.splice(pos,1)[0])}
}
return this}
,removeEvents:function(type){
	if(this.events){
	if(type){
	if(this.events[type]){
	this.events[type].keys.each(function(fn){
	this.removeEvent(type,fn)}
,this);
	this.events[type]=null}
}
else{
	for(var evType in this.events)this.removeEvents(evType);
	this.events=null}
}
return this}
,fireEvent:function(type,args){
	if(this.events&&this.events[type]){
	this.events[type].keys.each(function(fn){
	fn.bind(this,args)()}
,this)}
}
,getBrother:function(what){
	var el=this[what+'Sibling'];
	while($type(el)=='whitespace')el=el[what+'Sibling'];
	return $(el)}
,getPrevious:function(){
	return this.getBrother('previous')}
,getNext:function(){
	return this.getBrother('next')}
,getFirst:function(){
	var el=this.firstChild;
	while($type(el)=='whitespace')el=el.nextSibling;
	return $(el)}
,getLast:function(){
	var el=this.lastChild;
	while($type(el)=='whitespace')el=el.previousSibling;
	return $(el)}
,getParent:function(){
	return $(this.parentNode)}
,getChildren:function(){
	return $$(this.childNodes)}
,setProperty:function(property,value){
	switch(property){
	case'class':this.className=value;
	break;
	case'style':this.setStyles(value);
	break;
	case'name':if(window.ie6){
	var el=$(document.createElement('<'+this.getTag()+' name="'+value+'" />'));
	$each(this.attributes,function(attribute){
	if(attribute.name!='name')el.setProperty(attribute.name,attribute.value)}
);
	if(this.parentNode)this.replaceWith(el);
	return el}
default:this.setAttribute(property,value)}
return this}
,setProperties:function(source){
	for(var property in source)this.setProperty(property,source[property]);
	return this}
,setHTML:function(){
	this.innerHTML=$A(arguments).join('');
	return this}
,getProperty:function(property){
	return(property=='class')?this.className:this.getAttribute(property)}
,getTag:function(){
	return this.tagName.toLowerCase()}
,scrollTo:function(x,y){
	this.scrollLeft=x;
	this.scrollTop=y}
,getValue:function(){
	switch(this.getTag()){
	case'select':var values=[];
	$each(this.options,function(opt){
	if(opt.selected)values.push((opt.value!==null)?opt.value:opt.text)}
);
	return(this.multiple)?values:values[0];
	case'input':if(!(this.checked&&['checkbox','radio'].test(this.type))&&!['hidden','text','password'].test(this.type))break;
	case'textarea':return this.value}
return false}
,getSize:function(){
	return{
	'scroll':{
	'x':this.scrollLeft,'y':this.scrollTop}
,'size':{
	'x':this.offsetWidth,'y':this.offsetHeight}
,'scrollSize':{
	'x':this.scrollWidth,'y':this.scrollHeight}
}
}
,getPosition:function(overflown){
	overflown=overflown||[];
	var el=this,left=0,top=0;
	do{
	left+=el.offsetLeft||0;
	top+=el.offsetTop||0;
	el=el.offsetParent}
while(el);
	overflown.each(function(element){
	left-=element.scrollLeft||0;
	top-=element.scrollTop||0}
);
	return{
	'x':left,'y':top}
}
,getTop:function(){
	return this.getPosition().y}
,getLeft:function(){
	return this.getPosition().x}
,getCoordinates:function(overflown){
	var position=this.getPosition(overflown);
	var obj={
	'width':this.offsetWidth,'height':this.offsetHeight,'left':position.x,'top':position.y}
;
	obj.right=obj.left+obj.width;
	obj.bottom=obj.top+obj.height;
	return obj}
}
);
	window.addEvent=document.addEvent=Element.prototype.addEvent;
	window.removeEvent=document.removeEvent=Element.prototype.removeEvent;
	window.removeEvents=document.removeEvents=Element.prototype.removeEvents;
	var Garbage={
	elements:[],collect:function(element){
	Garbage.elements.push(element)}
,trash:function(){
	Garbage.collect(window);
	Garbage.collect(document);
	Garbage.elements.each(function(el){
	try{
	el.removeEvents();
	for(var p in Element.prototype)el[p]=null;
	el.extend=null}
catch(e){
}
}
)}
}
;
	window.addEvent('unload',Garbage.trash);
	var Event=new Class({
	initialize:function(event){
	this.event=event||window.event;
	this.type=this.event.type;
	this.target=this.event.target||this.event.srcElement;
	if(this.target.nodeType==3)this.target=this.target.parentNode;
	this.shift=this.event.shiftKey;
	this.control=this.event.ctrlKey;
	this.alt=this.event.altKey;
	this.meta=this.event.metaKey;
	if(['DOMMouseScroll','mousewheel'].test(this.type)){
	this.wheel=this.event.wheelDelta?(this.event.wheelDelta/(window.opera?-120:120)):-(this.event.detail||0)/ 3}
else if (this.type.test(/key/)){
	this.code=this.event.which||this.event.keyCode;
	for(var name in Event.keys){
	if(Event.keys[name]==this.code){
	this.key=name;
	break}
}
var fKey=this.code-111;
	if(fKey>0&&fKey<13)this.key='f'+fKey;
	this.key=this.key||String.fromCharCode(this.code).toLowerCase()}
else if(this.type.test(/mouse/)||(this.type=='click')){
	this.page={
	'x':this.event.pageX||this.event.clientX+document.documentElement.scrollLeft,'y':this.event.pageY||this.event.clientY+document.documentElement.scrollTop}
;
	this.client={
	'x':this.event.pageX?this.event.pageX-window.pageXOffset:this.event.clientX,'y':this.event.pageY?this.event.pageY-window.pageYOffset:this.event.clientY}
;
	this.rightClick=(this.event.which==3)||(this.event.button==2);
	switch(this.type){
	case'mouseover':this.relatedTarget=this.event.relatedTarget||this.event.fromElement;
	break;
	case'mouseout':this.relatedTarget=this.event.relatedTarget||this.event.toElement}
}
}
,stop:function(){
	this.stopPropagation();
	this.preventDefault();
	return this}
,stopPropagation:function(){
	if(this.event.stopPropagation)this.event.stopPropagation();
	else this.event.cancelBubble=true;
	return this}
,preventDefault:function(){
	if(this.event.preventDefault)this.event.preventDefault();
	else this.event.returnValue=false;
	return this}
}
);
	Event.keys={
	'enter':13,'up':38,'down':40,'left':37,'right':39,'esc':27,'space':32,'backspace':8,'delete':46}
;
	Function.extend({
	bindWithEvent:function(bind,args){
	return this.create({
	'bind':bind,'arguments':args,'event':Event}
)}
}
);
	var Chain=new Class({
	chain:function(fn){
	this.chains=this.chains||[];
	this.chains.push(fn);
	return this}
,callChain:function(){
	if(this.chains&&this.chains.length)this.chains.shift().delay(10,this)}
,clearChain:function(){
	this.chains=[]}
}
);
	var Events=new Class({
	addEvent:function(type,fn){
	if(fn!=Class.empty){
	this.events=this.events||{
}
;
	this.events[type]=this.events[type]||[];
	if(!this.events[type].test(fn))this.events[type].push(fn)}
return this}
,fireEvent:function(type,args,delay){
	if(this.events&&this.events[type]){
	this.events[type].each(function(fn){
	fn.create({
	'bind':this,'delay':delay,'arguments':args}
)()}
,this)}
return this}
,removeEvent:function(type,fn){
	if(this.events&&this.events[type])this.events[type].remove(fn);
	return this}
}
);
	var Options=new Class({
	setOptions:function(){
	var args=(arguments.length==1)?[this.options,arguments[0]]:arguments;
	this.options=$merge.apply(this,args);
	if(this.addEvent){
	for(var option in this.options){
	if(($type(this.options[option])=='function')&&option.test(/^on[A-Z]/))this.addEvent(option,this.options[option])}
}
return this}
}
);
	var Group=new Class({
	initialize:function(){
	this.instances=$A(arguments);
	this.events={
}
;
	this.checker={
}
}
,addEvent:function(type,fn){
	this.checker[type]=this.checker[type]||{
}
;
	this.events[type]=this.events[type]||[];
	if(this.events[type].test(fn))return false;
	else this.events[type].push(fn);
	this.instances.each(function(instance,i){
	instance.addEvent(type,this.check.bind(this,[type,instance,i]))}
,this);
	return this}
,check:function(type,instance,i){
	this.checker[type][i]=true;
	var every=this.instances.every(function(current,j){
	return this.checker[type][j]||false}
,this);
	if(!every)return;
	this.instances.each(function(current,j){
	this.checker[type][j]=false}
,this);
	this.events[type].each(function(event){
	event.call(this,this.instances,instance)}
,this)}
}
);
	function $E(selector,filter){
	return($(filter)||document).getElement(selector)}
;
	function $ES(selector,filter){
	return($(filter)||document).getElementsBySelector(selector)}
;
	Element.extend({
	getElements:function(selector,nocash){
	var items=[];
	var xpath=(document.evaluate)?true:false;
	selector=selector.clean().split(' ');
	for(var i=0,j=selector.length;
	i<j;
	i++){
	var sel=selector[i];
	var param=sel.match(/^(\w*|\*)(?:#([\w-]+)|\.([\w-]+))?(?:\[(\w+)(?:([!*^$]?=)["']?([^"'\]]*)["']?)?])?$/);
	if(!param)break;
	param[1]=(param[1])?param[1].toLowerCase():'*';
	if(xpath){
	var temp=[param[1]];
	if(param[2])temp.push('[@id="',param[2],'"]');
	if(param[3])temp.push('[contains(concat(" ",@class," ")," ',param[3],' ")]');
	if(param[4]){
	if(param[5]&&param[6]){
	switch(param[5]){
	case'*=':temp.push('[contains(@',param[4],',"',param[6],'")]');
	break;
	case'^=':temp.push('[starts-with(@',param[4],',"',param[6],'")]');
	break;
	case'$=':temp.push('[substring(@',param[4],',string-length(@',param[4],') - ',param[6].length,' + 1) = "',param[6],'"]');
	break;
	case'=':temp.push('[@',param[4],'="',param[6],'"]');
	break;
	case'!=':temp.push('[@',param[4],'!="',param[6],'"]')}
}
else temp.push('[@',param[4],']')}
items.push(temp.join(''));
	continue}
Filters.selector=param;
	if(i==0){
	if(param[2]){
	var el=this.getElementById(param[2]);
	if(!el||((param[1]!='*')&&(Element.prototype.getTag.call(el)!=param[1])))break;
	items=[el]}
else{
	items=$A(this.getElementsByTagName(param[1]))}
}
else{
	items=Elements.prototype.getElementsByTagName.call(items,param[1],true);
	if(param[2])items=items.filter(Filters.id)}
if(param[3])items=items.filter(Filters.className);
	if(param[4])items=items.filter(Filters.attribute)}
if(xpath)items=this.getElementsByXpath(items.join('//'));
	return(nocash)?items:$$(items)}
,getElementsByXpath:function(xp){
	var result=[];
	var xpath=document.evaluate('.//'+xp,this,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null);
	for(var i=0,j=xpath.snapshotLength;
	i<j;
	i++)result.push(xpath.snapshotItem(i));
	return result}
,getElementById:function(id){
	var el=document.getElementById(id);
	if(!el)return false;
	for(var parent=el.parentNode;
	parent!=this;
	parent=parent.parentNode){
	if(!parent)return false}
return el}
,getElement:function(selector){
	return this.getElementsBySelector(selector)[0]}
,getElementsBySelector:function(selector,nocash){
	var els=[];
	var sel=selector.split(',');
	for(var i=0,j=sel.length;
	i<j;
	i++){
	els.extend(this.getElements(sel[i],true))}
return(nocash)?els:$$(els)}
}
);
	document.extend({
	getElementsByClassName:function(className){
	return document.getElements('.'+className)}
,getElement:Element.prototype.getElement,getElements:Element.prototype.getElements,getElementsBySelector:Element.prototype.getElementsBySelector,getElementsByXpath:Element.prototype.getElementsByXpath}
);
	var Filters={
	selector:[],id:function(el){
	return(el.id==Filters.selector[2])}
,className:function(el){
	return(Element.prototype.hasClass.call(el,Filters.selector[3]))}
,attribute:function(el){
	var current=el.getAttribute(Filters.selector[4]);
	if(!current)return false;
	var operator=Filters.selector[5];
	if(!operator)return true;
	var value=Filters.selector[6];
	switch(operator){
	case'=':return(current==value);
	case'*=':return(current.test(value));
	case'^=':return(current.test('^'+value));
	case'$=':return(current.test(value+'$'));
	case'!=':return(current!=value)}
return false}
}
;
	Elements.extend({
	getElementsByTagName:function(tagName){
	var found=[];
	for(var i=0,j=this.length;
	i<j;
	i++)found.extend(this[i].getElementsByTagName(tagName));
	return found}
}
);
	var Hash=new Class({
	length:0,initialize:function(obj){
	this.obj={
}
;
	this.extend(obj)}
,get:function(key){
	return this.obj[key]}
,hasKey:function(key){
	return this.obj[key]!==undefined}
,set:function(key,value){
	if(value===undefined)return false;
	if(this.obj[key]===undefined)this.length++;
	this.obj[key]=value;
	return this}
,remove:function(key){
	if(this.obj[key]===undefined)return this;
	var obj={
}
;
	this.length--;
	for(var property in this.obj){
	if(property!=key)obj[property]=this.obj[property]}
this.obj=obj;
	return this}
,each:function(fn,bind){
	for(var property in this.obj)fn.call(bind||this,property,this.obj[property])}
,extend:function(obj){
	for(var property in obj){
	if(this.obj[property]===undefined)this.length++;
	this.obj[property]=obj[property]}
return this}
,empty:function(){
	return(this.length==0)}
,keys:function(){
	var keys=[];
	for(var property in this.obj)keys.push(property);
	return keys}
,values:function(){
	var values=[];
	for(var property in this.obj)values.push(this.obj[property]);
	return values}
}
);
	function $H(obj){
	return new Hash(obj)}
;
	var Color=new Class({
	initialize:function(color,type){
	if(color.isColor)return color;
	color.isColor=true;
	type=type||(color.push?'rgb':'hex');
	var rgb,hsb;
	switch(type){
	case'rgb':rgb=color;
	hsb=rgb.rgbToHsb();
	break;
	case'hsb':rgb=color.hsbToRgb();
	hsb=color;
	break;
	default:rgb=color.hexToRgb(true);
	hsb=rgb.rgbToHsb()}
rgb.hsb=hsb;
	return $extend(rgb,Color.prototype)}
,mix:function(){
	var colors=$A(arguments);
	var alpha=($type(colors[colors.length-1])=='number')?colors.pop():50;
	var rgb=this.copy();
	colors.each(function(color){
	color=new Color(color);
	for(var i=0;
	i<3;
	i++)rgb[i]=Math.round((rgb[i]/ 100 * (100 - alpha)) + (color[i] /100*alpha))}
);
	return new Color(rgb,'rgb')}
,invert:function(){
	return new Color(this.map(function(value){
	return 255-value}
))}
,setHue:function(value){
	return new Color([value,this.hsb[1],this.hsb[2]],'hsb')}
,setSaturation:function(percent){
	return new Color([this.hsb[0],percent,this.hsb[2]],'hsb')}
,setBrightness:function(percent){
	return new Color([this.hsb[0],this.hsb[1],percent],'hsb')}
}
);
	function $RGB(r,g,b){
	return new Color([r,g,b],'rgb')}
;
	function $HSB(h,s,b){
	return new Color([h,s,b],'hsb')}
;
	Array.extend({
	rgbToHsb:function(){
	var red=this[0],green=this[1],blue=this[2];
	var hue,saturation,brightness;
	var max=Math.max(red,green,blue),min=Math.min(red,green,blue);
	var delta=max-min;
	brightness=max/255;
	saturation=(max!=0)?delta/max:0;
	if(saturation==0){
	hue=0}
else{
	var rr=(max-red)/delta;
	var gr=(max-green)/delta;
	var br=(max-blue)/delta;
	if(red==max)hue=br-gr;
	else if(green==max)hue=2+rr-br;
	else hue=4+gr-rr;
	hue/=6;
	if(hue<0)hue++}
return[Math.round(hue*360),Math.round(saturation*100),Math.round(brightness*100)]}
,hsbToRgb:function(){
	var br=Math.round(this[2]/100*255);
	if(this[1]==0){
	return[br,br,br]}
else{
	var hue=this[0]%360;
	var f=hue%60;
	var p=Math.round((this[2]*(100-this[1]))/10000*255);
	var q=Math.round((this[2]*(6000-this[1]*f))/600000*255);
	var t=Math.round((this[2]*(6000-this[1]*(60-f)))/600000*255);
	switch(Math.floor(hue/60)){
	case 0:return[br,t,p];
	case 1:return[q,br,p];
	case 2:return[p,br,t];
	case 3:return[p,q,br];
	case 4:return[t,p,br];
	case 5:return[br,p,q]}
}
return false}
}
);
	window.extend({
	addEvent:function(type,fn){
	if(type=='domready'){
	if(this.loaded)fn();
	else if(!this.events||!this.events.domready){
	var domReady=function(){
	if(this.loaded)return;
	this.loaded=true;
	if(this.timer)this.timer=$clear(this.timer);
	Element.prototype.fireEvent.call(this,'domready');
	this.events.domready=null}
.bind(this);
	if(document.readyState&&this.khtml){
	this.timer=function(){
	if(['loaded','complete'].test(document.readyState))domReady()}
.periodical(50)}
else if(document.readyState&&this.ie){
	document.write("<script id=ie_ready defer src=javascript:void(0)><\/script>");
	$('ie_ready').onreadystatechange=function(){
	if(this.readyState=='complete')domReady()}
}
else{
	this.addEvent("load",domReady);
	document.addEvent("DOMContentLoaded",domReady)}
}
}
Element.prototype.addEvent.call(this,type,fn);
	return this}
,onDomReady:function(init){
	return this.addEvent('domready',init)}
}
);
	window.extend({
	getWidth:function(){
	if(this.khtml)return this.innerWidth;
	if(this.opera)return document.body.clientWidth;
	return document.documentElement.clientWidth}
,getHeight:function(){
	if(this.khtml)return this.innerHeight;
	if(this.opera)return document.body.clientHeight;
	return document.documentElement.clientHeight}
,getScrollWidth:function(){
	if(this.ie)return Math.max(document.documentElement.offsetWidth,document.documentElement.scrollWidth);
	if(this.khtml)return document.body.scrollWidth;
	return document.documentElement.scrollWidth}
,getScrollHeight:function(){
	if(this.ie)return Math.max(document.documentElement.offsetHeight,document.documentElement.scrollHeight);
	if(this.khtml)return document.body.scrollHeight;
	return document.documentElement.scrollHeight}
,getScrollLeft:function(){
	return this.pageXOffset||document.documentElement.scrollLeft}
,getScrollTop:function(){
	return this.pageYOffset||document.documentElement.scrollTop}
,getSize:function(){
	return{
	'size':{
	'x':this.getWidth(),'y':this.getHeight()}
,'scrollSize':{
	'x':this.getScrollWidth(),'y':this.getScrollHeight()}
,'scroll':{
	'x':this.getScrollLeft(),'y':this.getScrollTop()}
}
}
,getPosition:function(){
	return{
	'x':0,'y':0}
}
}
);
	var Fx={
}
;
	Fx.Transitions={
	linear:function(t,b,c,d){
	return c*t/d+b}
,sineInOut:function(t,b,c,d){
	return-c/2*(Math.cos(Math.PI*t/d)-1)+b}
}
;
	Fx.Base=new Class({
	options:{
	onStart:Class.empty,onComplete:Class.empty,onCancel:Class.empty,transition:Fx.Transitions.sineInOut,duration:500,unit:'px',wait:true,fps:50}
,initialize:function(options){
	this.element=this.element||null;
	this.setOptions(options);
	if(this.options.initialize)this.options.initialize.call(this)}
,step:function(){
	var time=$time();
	if(time<this.time+this.options.duration){
	this.cTime=time-this.time;
	this.setNow();
	this.increase()}
else{
	this.stop(true);
	this.now=this.to;
	this.increase();
	this.fireEvent('onComplete',this.element,10);
	this.callChain()}
}
,set:function(to){
	this.now=to;
	this.increase();
	return this}
,setNow:function(){
	this.now=this.compute(this.from,this.to)}
,compute:function(from,to){
	return this.options.transition(this.cTime,from,(to-from),this.options.duration)}
,start:function(from,to){
	if(!this.options.wait)this.stop();
	else if(this.timer)return this;
	this.from=from;
	this.to=to;
	this.time=$time();
	this.timer=this.step.periodical(Math.round(1000/this.options.fps),this);
	this.fireEvent('onStart',this.element);
	return this}
,stop:function(end){
	if(!this.timer)return this;
	this.timer=$clear(this.timer);
	if(!end)this.fireEvent('onCancel',this.element);
	return this}
,custom:function(from,to){
	return this.start(from,to)}
,clearTimer:function(end){
	return this.stop(end)}
}
);
	Fx.Base.implement(new Chain);
	Fx.Base.implement(new Events);
	Fx.Base.implement(new Options);
	Fx.CSS={
	select:function(property,to){
	if(property.test(/color/i))return this.Color;
	if(to.test&&to.test(' '))return this.Multi;
	return this.Single}
,parse:function(el,property,fromTo){
	if(!fromTo.push)fromTo=[fromTo];
	var from=fromTo[0],to=fromTo[1];
	if(!to&&to!=0){
	to=from;
	from=el.getStyle(property)}
var css=this.select(property,to);
	return{
	from:css.parse(from),to:css.parse(to),css:css}
}
}
;
	Fx.CSS.Single={
	parse:function(value){
	return parseFloat(value)}
,getNow:function(from,to,fx){
	return fx.compute(from,to)}
,getValue:function(value,unit){
	return value+unit}
}
;
	Fx.CSS.Multi={
	parse:function(value){
	return value.push?value:value.split(' ').map(function(v){
	return parseFloat(v)}
)}
,getNow:function(from,to,fx){
	var now=[];
	for(var i=0;
	i<from.length;
	i++)now[i]=fx.compute(from[i],to[i]);
	return now}
,getValue:function(value,unit){
	return value.join(unit+' ')+unit}
}
;
	Fx.CSS.Color={
	parse:function(value){
	return value.push?value:value.hexToRgb(true)}
,getNow:function(from,to,fx){
	var now=[];
	for(var i=0;
	i<from.length;
	i++)now[i]=Math.round(fx.compute(from[i],to[i]));
	return now}
,getValue:function(value){
	return'rgb('+value.join(',')+')'}
}
;
	Fx.Style=Fx.Base.extend({
	initialize:function(el,property,options){
	this.element=$(el);
	this.property=property;
	this.parent(options)}
,hide:function(){
	return this.set(0)}
,setNow:function(){
	this.now=this.css.getNow(this.from,this.to,this)}
,set:function(to){
	this.css=Fx.CSS.select(this.property,to);
	return this.parent(this.css.parse(to))}
,start:function(from,to){
	if(this.timer&&this.options.wait)return this;
	var parsed=Fx.CSS.parse(this.element,this.property,[from,to]);
	this.css=parsed.css;
	return this.parent(parsed.from,parsed.to)}
,increase:function(){
	this.element.setStyle(this.property,this.css.getValue(this.now,this.options.unit))}
}
);
	Element.extend({
	effect:function(property,options){
	return new Fx.Style(this,property,options)}
}
);
	Fx.Styles=Fx.Base.extend({
	initialize:function(el,options){
	this.element=$(el);
	this.parent(options)}
,setNow:function(){
	for(var p in this.from)this.now[p]=this.css[p].getNow(this.from[p],this.to[p],this)}
,set:function(to){
	var parsed={
}
;
	this.css={
}
;
	for(var p in to){
	this.css[p]=Fx.CSS.select(p,to[p]);
	parsed[p]=this.css[p].parse(to[p])}
return this.parent(parsed)}
,start:function(obj){
	if(this.timer&&this.options.wait)return this;
	this.now={
}
;
	this.css={
}
;
	var from={
}
,to={
}
;
	for(var p in obj){
	var parsed=Fx.CSS.parse(this.element,p,obj[p]);
	from[p]=parsed.from;
	to[p]=parsed.to;
	this.css[p]=parsed.css}
return this.parent(from,to)}
,increase:function(){
	for(var p in this.now)this.element.setStyle(p,this.css[p].getValue(this.now[p],this.options.unit))}
}
);
	Element.extend({
	effects:function(options){
	return new Fx.Styles(this,options)}
}
);
	Fx.Elements=Fx.Base.extend({
	initialize:function(elements,options){
	this.elements=$$(elements);
	this.parent(options)}
,setNow:function(){
	for(var i in this.from){
	var iFrom=this.from[i],iTo=this.to[i],iCss=this.css[i],iNow=this.now[i]={
}
;
	for(var p in iFrom)iNow[p]=iCss[p].getNow(iFrom[p],iTo[p],this)}
}
,set:function(to){
	var parsed={
}
;
	this.css={
}
;
	for(var i in to){
	var iTo=to[i],iCss=this.css[i]={
}
,iParsed=parsed[i]={
}
;
	for(var p in iTo){
	iCss[p]=Fx.CSS.select(p,iTo[p]);
	iParsed[p]=iCss[p].parse(iTo[p])}
}
return this.parent(parsed)}
,start:function(obj){
	if(this.timer&&this.options.wait)return this;
	this.now={
}
;
	this.css={
}
;
	var from={
}
,to={
}
;
	for(var i in obj){
	var iProps=obj[i],iFrom=from[i]={
}
,iTo=to[i]={
}
,iCss=this.css[i]={
}
;
	for(var p in iProps){
	var parsed=Fx.CSS.parse(this.elements[i],p,iProps[p]);
	iFrom[p]=parsed.from;
	iTo[p]=parsed.to;
	iCss[p]=parsed.css}
}
return this.parent(from,to)}
,increase:function(){
	for(var i in this.now){
	var iNow=this.now[i],iCss=this.css[i];
	for(var p in iNow)this.elements[i].setStyle(p,iCss[p].getValue(iNow[p],this.options.unit))}
}
}
);
	MultipleOpenAccordion=Fx.Elements.extend({
	initialize:function (togglers,elements,options){
	this.parent(elements,options);
	this.setOptions(this.options,$merge({
	openAll:true,allowMultipleOpen:true,firstElementsOpen:[0],start:'open-first',fixedHeight:false,fixedWidth:false,alwaysHide:true,wait:false,onActive:Class.empty,onBackground:Class.empty,height:true,opacity:true,width:false}
,options||{
}
));
	this.previousClick='nan';
	this.elementsVisible=[];
	togglers.each(function (tog,i){
	$(tog).addEvent('click',function (){
	this.toggleSection(i)}
.bind(this))}
,this);
	this.togglers=togglers;
	this.h={
}
;
	this.w={
}
;
	this.o={
}
;
	this.now=[];
	this.elements.each(function (el,i){
	this.now[i]={
}
;
	if(this.options.openAll&&this.options.allowMultipleOpen)$(el).setStyles({
	'overflow':'hidden'}
);
	else $(el).setStyles({
	'height':0,'overflow':'hidden'}
)}
,this);
	if(!this.options.openAll||!this.options.allowMultipleOpen){
	switch(this.options.start){
	case 'first-open':this.showSection(this.options.firstElementsOpen[0]);
	break;
	case 'open-first':this.toggleSection(this.options.firstElementsOpen[0]);
	break}
}
if(this.options.openAll&&this.options.allowMultipleOpen){
	this.showAll()}
else if(this.options.allowMultipleOpen){
	this.openSections(this.options.firstElementsOpen)}
}
,hideThis:function (i){
	this.elementsVisible[i]=false;
	if(this.options.height)this.h={
	'height':[this.elements[i].offsetHeight,0]}
;
	if(this.options.width)this.w={
	'width':[this.elements[i].offsetWidth,0]}
;
	if(this.options.opacity)this.o={
	'opacity':[this.now[i]['opacity']||1,0]}
}
,showThis:function (i){
	this.elementsVisible[i]=true;
	if(this.options.height)this.h={
	'height':[this.elements[i].offsetHeight,this.options.fixedHeight||this.elements[i].scrollHeight]}
;
	if(this.options.width)this.w={
	'width':[this.elements[i].offsetWidth,this.options.fixedWidth||this.elements[i].scrollWidth]}
;
	if(this.options.opacity)this.o={
	'opacity':[this.now[i]['opacity']||0,1]}
}
,toggleSection:function (iToToggle){
	if(iToToggle!=this.previousClick||this.options.alwaysHide||this.options.allowMultipleOpen){
	this.previousClick=iToToggle;
	var objObjs={
}
;
	var err=false;
	var madeInactive=false;
	this.elements.each(function (el,i){
	var update=false;
	this.now[i]=this.now[i]||{
}
;
	if(i==iToToggle){
	if(this.elementsVisible[i]&&(this.options.allowMultipleOpen||this.options.alwaysHide)){
	if(!(this.options.wait&&this.timer)){
	update=true;
	this.hideThis(i)}
else{
	this.previousClick='nan';
	err=true}
}
else if(!this.elementsVisible[i]){
	if(!(this.options.wait&&this.timer)){
	update=true;
	this.showThis(i)}
else{
	this.previousClick='nan';
	err=true}
}
}
else if(this.elementsVisible[i]&&!this.options.allowMultipleOpen){
	if(!(this.options.wait&&this.timer)){
	update=true;
	this.hideThis(i)}
else{
	this.previousClick='nan';
	err=true}
}
if(update)objObjs[i]=Object.extend(this.h,Object.extend(this.o,this.w))}
,this);
	if(err)return;
	if(!madeInactive)this.options.onActive.call(this,this.togglers[iToToggle],iToToggle);
	this.togglers.each(function (tog,i){
	if(!this.elementsVisible[i])this.options.onBackground.call(this,tog,i)}
,this);
	return this.custom(objObjs)}
}
,showSection:function (i,useFx){
	if($pick(useFx,false)){
	if(!this.elementsVisible[i])this.toggleSection(i)}
else{
	this.setSectionStyle(i,$(this.elements[i]).scrollWidth,$(this.elements[i]).scrollHeight,1);
	this.elementsVisible[i]=true;
	return true}
}
,hideSection:function (i,useFx){
	if($pick(useFx,false)){
	if(this.elementsVisible[i])this.toggleSection(i)}
else{
	this.setSectionStyle(i,0,0,0);
	this.elementsVisible[i]=false;
	return true}
}
,setSectionStyle:function (i,w,h,o){
	if(this.options.opacity)$(this.elements[i]).setOpacity(o);
	if(this.options.height)$(this.elements[i]).setStyle('height',h+'px');
	if(this.options.width)$(this.elements[i]).setStyle('width',w+'px')}
,showAll:function (){
	if(this.options.allowMultipleOpen){
	this.elements.each(function (el,idx){
	this.showSection(idx,false)}
,this)}
}
,hideAll:function (useFx){
	if(this.options.allowMultipleOpen){
	this.elements.each(function (el,idx){
	this.hideSection(idx,false)}
,this)}
}
,openSections:function (sections){
	if(this.options.allowMultipleOpen){
	this.elements.each(function (el,idx){
	if(sections.test(idx))this.showSection(idx,false);
	else this.hideSection(idx,false)}
,this)}
}
}
);
	MultipleOpenAccordion.implement(new Options);
	var YNavAccordion=new Class({
	initialize:function (options){
	try{
	this.setOptions({
	openAll:false,allowMultipleOpen:true,defaultOpenIndexes:[0],defaultOpenClassName:'forceOpen',allowCookie:false,cookieName:false,cookieDuration:999,stretchToggleSelector:'div.xNavGrp div.btn',stretcherSelector:'div.xNavGrp ul'}
,options);
	var start=(this.options.openAll)?'first-open':'open-first';
	if(this.options.allowCookie&&this.options.cookieName&&this.getPref())this.options.defaultOpenIndexes=this.getPref();
	var toggles=$$(this.options.stretchToggleSelector);
	var stretchers=$$(this.options.stretcherSelector);
	if(toggles&&stretchers){
	var forceOpen=toggles.filter(function (t,i){
	return t.hasClass(this.options.defaultOpenClassName)}
,this);
	forceOpen.extend(this.options.defaultOpenIndexes);
	this.Accordion=new MultipleOpenAccordion(toggles,stretchers,{
	openAll:this.options.openAll,allowMultipleOpen:this.options.allowMultipleOpen,firstElementsOpen:forceOpen,start:start}
)}
}
catch(e){
	dbug.log('nav accordion error:%s',e)}
}
,savePref:function (iToShow){
	Cookie.set(Json.toString (this.options.cookieName),iToShow,{
	duration:cookieDuration}
)}
,getPref:function (){
	return Json.evaluate(Cookie.get(this.options.cookieName))}
}
);
	YNavAccordion.implement(new Options);
	YNavAccordion.implement(new Events);
	var Ycarousel=new Class({
	initialize:function (container,options){
	this.container=$(container);
	if(!this.container.hasClass('hasCarousel')){
	this.container.addClass('hasCarousel');
	this.slides=[];
	this.buttons=[];
	this.setOptions({
	onRotate:Class.empty,onStop:Class.empty,onAutoPlay:Class.empty,onShowSlide:Class.empty,slidesSelector:".slide",buttonsSelector:".button",slideInterval:4000,transitionDuration:700,startIndex:0,buttonOnClass:"selected",buttonOffClass:"off",rotateAction:"none",rotateActionDuration:100,autoplay:true}
,options);
	this.slides=$(container).getElements(this.options.slidesSelector);
	this.buttons=$(container).getElements(this.options.buttonsSelector);
	this.createFx();
	this.showSlide(this.options.startIndex);
	if(this.options.autoplay)this.autoplay();
	if(this.options.rotateAction!='none')this.setupAction(this.options.rotateAction);
	return this}
else return false}
,setupAction:function (action){
	this.buttons.each(function (el,idx){
	$(el).addEvent(action,function (){
	this.slideFx.setOptions(this.slideFx.options,{
	duration:this.options.rotateActionDuration}
);
	if(this.currentSlide!=idx)this.showSlide(idx);
	this.stop()}
.bind(this))}
,this)}
,createFx:function (){
	this.slideFx=new Fx.Elements(this.slides,{
	duration:this.options.transitionDuration}
);
	this.slides.each(function (slide){
	slide.setStyle('opacity',0)}
)}
,showSlide:function (slideIndex){
	var action={
}
;
	this.slides.each(function (slide,index){
	if(index==slideIndex&&index!=this.currentSlide){
	$(this.buttons[index]).removeClass(this.options.buttonOffClass).addClass(this.options.buttonOnClass);
	action[index.toString ()]={
	'opacity':[1]}
}
else{
	$(this.buttons[index]).removeClass(this.options.buttonOnClass).addClass(this.options.buttonOffClass);
	action[index.toString ()]={
	'opacity':[0]}
}
}
,this);
	this.fireEvent('onShowSlide',slideIndex);
	this.currentSlide=slideIndex;
	this.slideFx.start(action)}
,autoplay:function (){
	this.createFx();
	this.slideshowInt=this.rotate.periodical(this.options.slideInterval,this);
	this.fireEvent('onAutoPlay')}
,stop:function (){
	clearInterval(this.slideshowInt);
	this.fireEvent('onStop')}
,rotate:function (){
	current=this.currentSlide;
	next=(current+1>=this.slides.length)?0:current+1;
	this.showSlide(next);
	this.fireEvent('onRotate')}
,show:function (){
	$(this.options.carouselContainer).setStyle('visibility','visible');
	if(!$(this.options.carouselContainer).visible())$(this.options.carouselContainer).show()}
,hide:function (){
	$(this.options.carouselContainer).setStyle('visibility','hidden')}
}
);
	Ycarousel.implement(new Options);
	Ycarousel.implement(new Events);
	var YcarouselWithButtons=Ycarousel.extend({
	initialize:function (el,options){
	this.parent(el,$merge({
	bubbleButtonBGImgSelector:'.bbg',buttonOnGifSrc:'images/green_button.gif',buttonOffGifSrc:'images/gray_button.gif'}
,options))}
,showSlide:function (slideIndex){
	this.buttons.each(function (button,index){
	$(button).getElement(this.options.bubbleButtonBGImgSelector).src=(index==slideIndex)?this.options.buttonOnGifSrc:this.options.buttonOffGifSrc}
,this);
	this.parent(slideIndex)}
}
);
	var carousel=null;
	window.onDomReady(function (){
	if($('Carousel')){
	carousel=new YcarouselWithButtons($('Carousel'),{
	buttonsSelector:'.bubble',rotateAction:'mouseover'}
)}
}
);
	

CSS代码(css.css):

.kuan460{WIDTH:460px;TEXT-ALIGN:left}
.blue01:link{FONT-SIZE:14px;COLOR:#074495;TEXT-DECORATION:none}
.blue01:visited{FONT-SIZE:14px;COLOR:#074495;TEXT-DECORATION:none}
.blue01:active{FONT-SIZE:14px;COLOR:#074495;TEXT-DECORATION:underline}
.blue01:hover{FONT-SIZE:14px;COLOR:#074495;TEXT-DECORATION:underline}
#Carousel{VISIBILITY:hidden;MARGIN-BOTTOM:0px;WIDTH:460px;HEIGHT:200px}
#Carousel .bg{WIDTH:460px;POSITION:absolute;HEIGHT:200px}
#Carousel .slide{WIDTH:460px;POSITION:absolute;HEIGHT:200px}
#Carousel .frame{WIDTH:460px;POSITION:absolute;HEIGHT:200px}
#Carousel .slide .text{FONT-SIZE:12px;FLOAT:left;MARGIN:10px 0px 0px 18px;WIDTH:250px;LINE-HEIGHT:16px;FONT-FAMILY:arial;POSITION:absolute}
#Carousel .slide .text H1{PADDING-RIGHT:0px;PADDING-LEFT:0px;FONT-WEIGHT:bold;FONT-SIZE:20px;PADDING-BOTTOM:0px;MARGIN:0px 0px 6px;LINE-HEIGHT:22px;PADDING-TOP:0px;FONT-FAMILY:"����",Arial Black,sans-serif}
#Carousel .slide .text H1 A{COLOR:#000;TEXT-DECORATION:none}
#Carousel .slide .text A{COLOR:#06c}
#Carousel .slide .text H1 A:hover{TEXT-DECORATION:underline}
#Carousel .dark .text H1 A{COLOR:#fff}
#Carousel #music .text H1 A{COLOR:#fff}
#Carousel #music .text{COLOR:#e3e3e3}
#Carousel #music .text A{COLOR:#fff}
#Carousel .dark{COLOR:#fff}
#Carousel .dark .text A{COLOR:#ffff00}
#Carousel .slide .image{MARGIN-TOP:10px;FLOAT:right;WIDTH:200px;TEXT-ALIGN:center}
#Carousel .slide .screen{MARGIN-TOP:10px;WIDTH:200px}
#Carousel .slide .album{MARGIN:19px 0px 0px;WIDTH:180px}
#Carousel .slide .feature{MARGIN-TOP:30px}
#Carousel #CaroLinks{MARGIN-TOP:112px;VISIBILITY:visible;MARGIN-LEFT:9px;WIDTH:460px;LINE-HEIGHT:42px;POSITION:absolute}
#CaroLinks .bubble .bbg{POSITION:absolute}
#CaroLinks .bubble{FLOAT:left;WIDTH:222px;HEIGHT:42px}
#CaroLinks .bubble#on A{TEXT-DECORATION:underline}
#CaroLinks .bubble A IMG{MARGIN-TOP:2px;FLOAT:left;MARGIN-RIGHT:6px}
#CaroLinks .bubble A SPAN{MARGIN-TOP:8px;DISPLAY:block;FLOAT:left;OVERFLOW:hidden;WIDTH:158px;CURSOR:pointer;WHITE-SPACE:nowrap;TEXT-OVERFLOW:clip}
#CaroLinks .bubble A{MARGIN-TOP:5px;DISPLAY:block;FONT-SIZE:12px;MARGIN-LEFT:10px;OVERFLOW:hidden;WIDTH:200px;COLOR:#06c;LINE-HEIGHT:15px;MARGIN-RIGHT:5px;FONT-FAMILY:verdana;POSITION:absolute;HEIGHT:30px;TEXT-OVERFLOW:clip;TEXT-DECORATION:none}
#CaroLinks .bubble A:hover{TEXT-DECORATION:underline}
附件:下载该文件资源,减少时间成本(增值服务)
留言
该资源可下载
File Source
.rar
80.78 KB
Html 焦点滚动特效2
最新结算
jquery虚拟键盘中文打字效果js代码
类型: .rar 金额: CNY 2.31¥ 状态: 待结算 详细>
jquery虚拟键盘中文打字效果js代码
类型: .rar 金额: CNY 0.29¥ 状态: 待结算 详细>
HTML5实现CSS滤镜图片切换特效代码
类型: .rar 金额: CNY 2.31¥ 状态: 待结算 详细>
jQuery头像裁剪插件cropbox js代码
类型: .rar 金额: CNY 0.29¥ 状态: 待结算 详细>
jQuery头像裁剪插件cropbox js代码
类型: .rar 金额: CNY 2.31¥ 状态: 待结算 详细>
CSS3制作3D图片立方体旋转特效
类型: .rar 金额: CNY 2.31¥ 状态: 待结算 详细>
CSS3制作3D图片立方体旋转特效
类型: .rar 金额: CNY 0.29¥ 状态: 待结算 详细>
CSS3制作3D图片立方体旋转特效
类型: .rar 金额: CNY 2.31¥ 状态: 待结算 详细>
CSS3制作3D图片立方体旋转特效
类型: .rar 金额: CNY 0.29¥ 状态: 待结算 详细>
jQuery+css3实现信封效果
类型: .rar 金额: CNY 0.29¥ 状态: 待结算 详细>
我们力求给您提供有用的文章,再此基础上,会附加营收资源,不做任何广告,让平台可以更好发展 若您发现您的权利被侵害,或使用了您的版权,请发邮件联系 sunlifel@foxmail.com ggbig觉得 : 不提供源码的文章不是好文章
合作伙伴
联系我们
  • QQ:21499807
  • 邮箱:sunlifel@foxmail.com
  • QQ扫一扫加QQ
    QQ扫一扫
Copyright 2023-2024 ggbig.com·皖ICP备2023004211号-1
打赏文章