美文网首页
用CSS控制输入框input悬停交互样式

用CSS控制输入框input悬停交互样式

作者: 培训机构 | 来源:发表于2016-12-29 15:06 被阅读148次

    用CSS控制输入框input悬停交互样式

    HTML5教程制作表单的时候,实现鼠标悬停交互效果有多种方法:

    1、在xhtml中直接写入onmouseover、onmouseout脚本就可以实现了,但这样就违背了web标准所倡导的内容、表现相分离的原则。以后若要对此进行修改也将会很繁琐。这样直接写入xhtml也会让页面代码增加,如果只是一个input输入框或许是无所谓的,如果是几十个几百个,增加的字节数就很宠大了。

    2、在xhtml中加入小脚本,鼠标经过时可以切换CSS。具体内容请看这篇文章。虽然实现了内容、表现相分离,以后的修改也会很方便。但同样会让页面代码增加。

    我们有没有更好的办法来实现输入框input样式悬停交互的效果呢?

    我们今天就讨论这样的方法,直接在CSS文件中写入悬停交互效果的小脚本。不但实现了内容与表现分离,而且使xhtml代码减小,促进了代码重用、更加的优化。

    这一方法的原理,主要是应用CSS的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=utf-8 /

    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=utf-8 /

    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

    相关文章

      网友评论

          本文标题:用CSS控制输入框input悬停交互样式

          本文链接:https://www.haomeiwen.com/subject/xmqpvttx.html