网站首页/技术开发列表/内容

跟随鼠标的彩色文字JS代码如何写

技术开发2023-06-21阅读
编程(Programming)是编定程序的中文简称,就是让计算机代码解决某个问题,对某个计算体系规定一定的运算方式,使计算体系按照该计算方式运行,并最终得到相应结果的过程。为了使计算机能够理解(understand)人的意图,人类就必须将需解决的问题的思路、方法和手段通过计算机能够理解的形式告诉计算机,使得计算机能够根据人的指令一步一步去工作,完成某种特定的任务。这种人和计算体系之间交流的过程就是编程。

【实例名称】

跟随鼠标的彩色文字

【实例描述】

 跟随鼠标的文本可以很轻松实现,本例要实现的是文字不仅要跟随鼠标,而且颜色会不断变化。

【实例代码】

 

<SCRIPT language=javascript>  var message="欢 迎 参 加 北 京 奥 运 会 !";  //要跟随鼠标的文本  var x,y;  var step=15;                                 //文本之间的距离  var flag=0;

 message=message.split("");                   //将文本切换成数组  var xpos=new Array();  for (i=0;i<=message.length-1;i++) {          //设置所有文本的初始x坐标   xpos[i]=-50;  }  var ypos=new Array();  for (i=0;i<=message.length-1;i++) {          //设置所有文本的初始Y坐标   ypos[i]=-50;  }  function handlerXY(e) {                                              //根据浏览器的不同,获取鼠标的x,y坐标   x = (document.layers) ? e.pageX : document.body.scrollLeft+event.clientX+10;   y = (document.layers) ? e.pageY : document.body.scrollTop+event.clientY;   flag=1;  }  function makesnake() {   if (flag==1 && document.all) {        for (i=message.length-1; i>=1; i--) {        xpos[i]=xpos[i-1]+step;        //设置文本之间的显示距离     ypos[i]=ypos[i-1];             //设置文本的y坐标       }    xpos[0]=x+step;    ypos[0]=y;    for (i=0; i<=message.length-1; i++) {         var thisspan = eval("span"+(i)+".style");         thisspan.posLeft=xpos[i];     thisspan.posTop=ypos[i];     thisspan.color=Math.random() * 255 * 255 * 255 + Math.random() * 255 * 255 + Math.random() * 255;        }   }   else if (flag==1 && document.layers) {        for (i=message.length-1; i>=1; i--) {        xpos[i]=xpos[i-1]+step;     ypos[i]=ypos[i-1];        }    xpos[0]=x+step;    ypos[0]=y;

   for (i=0; i<message.length-1; i++) //根据字符的个数创建多个span元素,用来显示字符    {         var thisspan = eval("document.span"+i);         thisspan.left=xpos[i];    //指定span的x坐标     thisspan.top=ypos[i];         //指定span的y坐标                                   //创建随机的颜色值     thisspan.color=Math.random() * 255 * 255 * 255 + Math.random() * 255 * 255 + Math.random() * 255;    }   }  }  for (i=0;i<=message.length-1;i++) {      //循环输出文本信息       document.write("<span id='span"+i+"' class='spanstyle'>");   document.write(message[i]);       document.write("</span>");  }

 if (document.layers) {   document.captureEvents(Event.MOUSEMOVE);  }  document.onmousemove = handlerXY;  function firstLoad() {                   //窗体一加载便触发的事件   makesnake();                         //实现跟随鼠标文本的方法   window.setTimeout("firstLoad();", 5);//定时执行此方法  } </SCRIPT>

 

【运行效果】

运行效果

【难点剖析】

本例的重点如下:
    (1)动态输出span元素,用来显示文本内容。动态输出span元素使用的是“document.write”方法,此处要注意每个“span”元素ID的创建方式。
    (2)获取鼠标的坐标,根据坐标位置显示文本信息。获取鼠标坐标使用的是“event.clientx”和“event.clientY”属性。
    (3)动态实现颜色的变化。本例使用了“Math.random0*255*255 * 255”创建一个随机颜色值,然后使用span元素的“color”属性设置文本最后显示的颜色。

【源码下载】

本实例JS代码下载

 


使用编程语言写的程序,由于每条指令都对应计算机一个特定的基本动作,所以程序占用内存少、执行效率高。

……

相关阅读