1. Display effect: 2, html structure <div class="process_list-lpu"> <div class="process_line"></div> <div class="content_list"> <ul> <li><a href="javascipt:;">End customer get product<b>1</b></a> </li> <li><a href="javascipt:;">Log in to EFOSE website and present installation or maintenance requirements <b>2</b></a></li> <li><a href="javascipt:;">EFOSE prefer contact service point<b>3</b></a> </li> <li style="margin-left:115px;"><a href="javascipt:;">Customer contact service point to get service<b>4</b></a> </li> <li><a href="javascipt:;">Customer pays the bill directly or EFOSE pays the maintenance cost<b>5</b></a> </li> </ul> <div class="clear"></div> </div> </div> 3. Main CSS styles .line-lpu{ height:55px; position:relative; width:100%; overflow:hidden;} .line-lpu span{ width:43px; height:46px; background:url('https://www.efose.com/images/banners/lpu_03.png') no-repeat; position:absolute;top:0;} .border-lpu{border-bottom:1px solid #959595; height:23px; } .join-lpu li{ width:19%; float:left; margin-right:8px;background:none; padding:0; } .join-lpu li a{ display:block; color:#606060; text-decoration:none; border:1px solid #959595; min-height:215px; padding:10px;position:relative; overflow:hidden;} .join-lpu li a:hover{border:1px solid #337ab7;} .join-lpu li b{ font-size:60px; position:absolute; bottom:7px; right:-1px; font-style:italic; color:#c7c7c7;} .clear{clear:both;} .step-lpu span{ background:url('https://www.efose.com/images/banners/icon-lpu.png') no-repeat; display:block; width:75px; height:65px; margin-left:28px;} .step-lpu .icon0{ background-position:0 0;} .step-lpu .icon1{ background-position:0 -70px;} .step-lpu .icon2{ background-position:0 -140px;} .step-lpu .icon3{ background-position:0 -204px; height:58px; margin-bottom:7px;} .step-lpu .icon4{ background-position:0 -260px;} 4. Writing JavaScript <script type="text/javascript"> //Instantiate animationHover object window.onload = function(){ var ah = new animationHover(); ah.init(); }; //Initialize label object function animationHover(){ this.step = document.getElementById('step'); this.stepLi = this.step.getElementsByTagName('li'); this.line = document.getElementById('line'); this.attr = null; this.timer = null; this.target = null; } //Initialize event animationHover.prototype.init=function(){ This = this; for(var i=0;i<this.stepLi.length;i++){ this.stepLi[i].index=i; //Bind event to li tag this.stepLi[i].onmouseover=function(e){ var myIndex=this.index; This.onOver(This.line,(myIndex*162+55)); }; this.stepLi[i].onmouseout=function(){ This.line.style.left=myIndex*162+55+'px'; }; } }; //Define the mouse processing function animationHover.prototype.onOver=function(obj,target){ This=this; clearInterval(this.timer); This.target=target; timer = setInterval(function(){ var target=This.target; //Stop target point var attrValue=parseInt(This.getStyle(obj,'left')); var dx=target-attrValue; //"distance" from the target point var speed=1/10*dx; speed=speed>0?Math.ceil(speed):Math.floor(speed); //Prevent jitter caused by rounding if(target==attrValue) clearInterval(timer); //If you reach the target point, turn off the timer else{ obj.style.left=attrValue+speed+'px'; } },100); }; //Get the css attribute value of the current tag object animationHover.prototype.getStyle = function (obj, attr) { if (obj.currentStyle) { return obj.currentStyle[attr]; }else{ return getComputedStyle(obj,false)[attr]; } }; </script> Summarize The above is the html+css+javascript that I introduced to you to achieve the selection effect of following the mouse movement. I hope it will be helpful to you. If you have any questions, please leave me a message and I will reply to you in time! |
<<: Common attacks on web front-ends and ways to prevent them
>>: Detailed explanation of js event delegation
Recently, the project uses kubernetes (hereinafte...
Table of contents 1. Understand the basics 2. Con...
Now many mobile phones have the function of switc...
I updated MySQL 8.0 today. The first problem: Nav...
Take zabbix's own WEB interface as an example...
Table of contents Preface No.1 A focus No.2 Extra...
Using the CSS3 border-image property, you can set...
Traceroute allows us to know the path that inform...
In SQL, GROUP BY is used to group data in the res...
Table of contents 1. Basic conditions for databas...
Table of contents 1. Initialization structure 2. ...
The reason for writing such an article is that on...
Discuz! Forum has many configuration options in th...
Before the release of Microsoft IE 5.0, the bigges...
Table of contents Preface advantage: shortcoming:...