zoukankan      html  css  js  c++  java
  • 用CSS控制输入框input悬停交互样式

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

      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 {40px;}
    .in80 {80px;}
    .in120 {120px;}
    .in200 {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>

  • 相关阅读:
    开发servlet三种方式
    puppet 启动失败
    linux 内核 中链表list
    software level
    ubuntu 使用 root “sudo /bin/bash”
    linux 内存管理
    linux kernel "current" macro
    hello.hs haskell
    ubuntu samba
    微信小程序中使用 npm包管理 (保姆式教程)
  • 原文地址:https://www.cnblogs.com/zzh/p/1359783.html
Copyright © 2011-2022 走看看