CSS 网页表单实现鼠标悬停交互效果

时间:2021-05-08

制作表单的时候,实现鼠标悬停交互效果有多种方法:
1、在xhtml中直接写入onmouseover、onmouseout脚本就可以实现了,但这样就违背了web标准所倡导的内容、表现相分离的原则。以后若要对此进行修改也将会很繁琐。这样直接写入xhtml也会让页面代码增加,如果只是一个input输入框或许是无所谓的,如果是几十个几百个,增加的字节数就很宠大了。
2、在xhtml中加入小脚本,鼠标经过时可以切换CSS。具体内容请看这篇文章。虽然实现了内容、表现相分离,以后的修改也会很方便。但同样会让页面代码增加。
  我们有没有更好的办法来实现输入框input样式悬停交互的效果呢?
  我们今天就讨论这样的方法,直接在CSS文件中写入悬停交互效果的小脚本。不但实现了内容与表现分离,而且使xhtml代码减小,促进了代码重用、更加的优化。
  这一方法的原理,主要是应用CSS的expression,关于expression的更多介绍,请看这篇文章。

复制代码代码如下:
input {star : expression(
onmouseover=function(){this.style.borderColor="#060"},
onmouseout=function(){this.style.borderColor="#c00"})}
上面的代码,声明了,当鼠标移上去的时候,边框的颜色是#060,当鼠标移除的时候边框的颜色是#c00。我们看一下运行效果:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>用CSS控制输入框input悬停交互样式</title> <style type="text/css"> <!-- input {border:1px solid #c00;} input {star : expression( onmouseover=function(){this.style.borderColor="#060"}, onmouseout=function(){this.style.borderColor="#c00"})} --> </style> </head> <body> 姓名:<input type="text" /><br> 年龄:<input type="text" /><br> 性别:<input type="text" /><br> 手机:<input type="text" /><br> 地址:<input type="text" /><br> </body> </html>
提示:您可以先修改部分代码再运行
你也可以这样做
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>用CSS控制输入框input悬停交互样式</title> <style type="text/css"> <!-- input {border:1px solid #c00; background:#fff; } input {star : expression( onmouseover=function(){this.style.backgroundColor="#eee"}, onmouseout=function(){this.style.backgroundColor="#fff"})} .in40 {width:40px;} .in80 {width:80px;} .in120 {width:120px;} .in200 {width:200px;} --> </style> </head> <body> 姓名:<input class="in80" type="text" /><br> 年龄:<input class="in40" type="text" /><br> 性别:<input class="in40" type="text" /><br> 手机:<input class="in120" type="text" /><br> 地址:<input class="in200" type="text" /><br> </body> </html>
提示:您可以先修改部分代码再运行

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章