| ||||
Hum... sip, con html dinámico puede hacerse.... A ver si es por algo así que preguntas
Código:
Y en body....<script language="javascript"> //script por tunait //http://javascript.tunait.com/ var colorDefecto = '#CC00FF' //color para los enlaces en estado normal var colores = new Array( '#FFCC66', '#3399CC', '#669966', '#993333', '#996600', '#9966CC' ) //cambia y/o añade los colores que quieras var cont = 0 function enlaces(){ for (m=0; m < document.getElementsByTagName('a').length; m++) { document.getElementsByTagName('a')[m].onmouseover = function(){ this.style.color = colores[cont] if(cont < (colores.length-1)){cont++} else{cont = 0} } document.getElementsByTagName('a')[m].onmouseout = function(){ this.style.color = colorDefecto } } } </script> <body onload="enlaces()"> Dime si te sirvió. traslado el tema al foro de javascript movido desde CSS saludos |
| ||||
Ah, vale, pues entonces así
Código:
Y en body lo mismo que antes <script language="javascript"> var colorDefecto = '#CC00FF',cont = 0 var colores = new Array( '#FFCC66', '#3399CC', '#669966', '#993333', '#996600', '#9966CC' ) function colorines(cual){ cual.style.color = colores[cont] if(cont < (colores.length-1)){cont++} else{cont = 0} cual2 = cual tiempo = setTimeout('colorines(cual2)',50) } function enlaces(){ for (m=0; m < document.getElementsByTagName('a').length; m++) { document.getElementsByTagName('a')[m].onmouseover = function(){ colorines(this) } document.getElementsByTagName('a')[m].onmouseout = function(){ clearTimeout(tiempo); this.style.color = colorDefecto } } } </script> |
| ||||
Hola hechicero (Hola tunait ... ) Yo tengo este, que se llama Rainbow y hace el efecto que quieres.
Código:
Es más largo que el de tunait, pero hace un efecto muy bonito.<script language="javascript"> var rate = 20; // Increase amount(The degree of the transmutation) if (document.getElementById) window.onerror=new Function("return true") var objActive; // The object which event occured in var act = 0; // Flag during the action var elmH = 0; // Hue var elmS = 128; // Saturation var elmV = 255; // Value var clrOrg; // A color before the change var TimerID; // Timer ID var IE = 0; var Mozilla = 0; // Browser check var szUA = navigator.userAgent; if (szUA.indexOf("MSIE 6.") >= 0) { IE = 6; } else if (szUA.indexOf("Mozilla/5.") >= 0) { Mozilla = 6; } else if(szUA.indexOf("MSIE 5.") >= 0) { IE = 5; } else if(szUA.indexOf("MSIE 4.") >= 0) { IE = 4; } else if(szUA.indexOf("Mozilla/4.") >= 0) { Mozilla = 4; } if (IE >= 4) { document.onmouseover = doRainbowAnchor; document.onmouseout = stopRainbowAnchor; } else if (Mozilla >= 6) { document.captureEvents(Event.MOUSEOVER | Event.MOUSEOUT); document.onmouseover = Mozilla_doRainbowAnchor; document.onmouseout = Mozilla_stopRainbowAnchor; } //============================================================================= // doRainbow // This function begins to change a color. //============================================================================= function doRainbow(obj) { if (act == 0) { act = 1; if (obj) objActive = obj; else objActive = event.srcElement; clrOrg = objActive.style.color; TimerID = setInterval("ChangeColor()",100); } } //============================================================================= // stopRainbow // This function stops to change a color. //============================================================================= function stopRainbow() { if (act) { objActive.style.color = clrOrg; clearInterval(TimerID); act = 0; } } //============================================================================= // doRainbowAnchor // This function begins to change a color. (of a anchor, automatically) //============================================================================= function doRainbowAnchor() { if (act == 0) { var obj = event.srcElement; while (obj.tagName != 'A' && obj.tagName != 'BODY') { obj = obj.parentElement; if (obj.tagName == 'A' || obj.tagName == 'BODY') break; } if (obj.tagName == 'A' && obj.href != '') { objActive = obj; act = 1; clrOrg = objActive.style.color; TimerID = setInterval("ChangeColor()",100); } } } //============================================================================= // stopRainbowAnchor // This function stops to change a color. (of a anchor, automatically) //============================================================================= function stopRainbowAnchor() { if (act) { if (objActive.tagName == 'A') { objActive.style.color = clrOrg; clearInterval(TimerID); act = 0; } } } //============================================================================= // Mozilla_doRainbowAnchor(for Netscape6 and Mozilla browser) // This function begins to change a color. (of a anchor, automatically) //============================================================================= function Mozilla_doRainbowAnchor(e) { if (act == 0) { obj = e.target; while (obj.nodeName != 'A' && obj.nodeName != 'BODY') { obj = obj.parentNode; if (obj.nodeName == 'A' || obj.nodeName == 'BODY') break; } if (obj.nodeName == 'A' && obj.href != '') { objActive = obj; act = 1; clrOrg = obj.style.color; TimerID = setInterval("ChangeColor()",100); } } } //============================================================================= // Mozilla_stopRainbowAnchor(for Netscape6 and Mozilla browser) // This function stops to change a color. (of a anchor, automatically) //============================================================================= function Mozilla_stopRainbowAnchor(e) { if (act) { if (objActive.nodeName == 'A') { objActive.style.color = clrOrg; clearInterval(TimerID); act = 0; } } } //============================================================================= // Change Color // This function changes a color actually. //============================================================================= function ChangeColor() { objActive.style.color = makeColor(); } //============================================================================= // makeColor // This function makes rainbow colors. //============================================================================= function makeColor() { // Don't you think Color Gamut to look like Rainbow? // HSVtoRGB if (elmS == 0) { elmR = elmV; elmG = elmV; elmB = elmV; } else { t1 = elmV; t2 = (255 - elmS) * elmV / 255; t3 = elmH % 60; t3 = (t1 - t2) * t3 / 60; if (elmH < 60) { elmR = t1; elmB = t2; elmG = t2 + t3; } else if (elmH < 120) { elmG = t1; elmB = t2; elmR = t1 - t3; } else if (elmH < 180) { elmG = t1; elmR = t2; elmB = t2 + t3; } else if (elmH < 240) { elmB = t1; elmR = t2; elmG = t1 - t3; } else if (elmH < 300) { elmB = t1; elmG = t2; elmR = t2 + t3; } else if (elmH < 360) { elmR = t1; elmG = t2; elmB = t1 - t3; } else { elmR = 0; elmG = 0; elmB = 0; } } elmR = Math.floor(elmR).toString(16); elmG = Math.floor(elmG).toString(16); elmB = Math.floor(elmB).toString(16); if (elmR.length == 1) elmR = "0" + elmR; if (elmG.length == 1) elmG = "0" + elmG; if (elmB.length == 1) elmB = "0" + elmB; elmH = elmH + rate; if (elmH >= 360) elmH = 0; return '#' + elmR + elmG + elmB; } </script> Saludos a amb@s |