这篇文章主要介绍“CSS怎么控制input样式和悬停交互”,在日常操作中,相信很多人在CSS怎么控制input样式和悬停交互问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CS
这篇文章主要介绍“CSS怎么控制input样式和悬停交互”,在日常操作中,相信很多人在CSS怎么控制input样式和悬停交互问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS怎么控制input样式和悬停交互”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
本文向大家描述一下用CSS控制输入框input样式和悬停交互的方法,直接在CSS文件中写入悬停交互效果的小脚本,不但实现了内容与表现分离,而且使xhtml代码减小,促进了代码重用、更加的优化。
用CSS控制输入框input样式和悬停交互
我们在制作表单的时候,往往希望有鼠标悬停交互效果。实现这样的效果,我们有多种方法:
1、在xhtml中直接写入onmouseover、onmouseout脚本就可以实现了,但这样就违背了WEB标准所倡导的内容、表现相分离的原则。以后若要对此进行修改也将会很繁琐。这样直接写入xhtml也会让页面代码增加,如果只是一个input输入框或许是无所谓的,如果是几十个几百个,增加的字节数就很宠大了。
2、在xhtml中加入小脚本,鼠标经过时可以切换CSS。具体内容请看这篇文章。虽然实现了内容、表现相分离,以后的修改也会很方便。但同样会让页面代码增加。
我们有没有更好的办法来实现输入框input样式悬停交互的效果呢?
我们今天就讨论这样的方法,直接在CSS文件中写入悬停交互效果的小脚本。不但实现了内容与表现分离,而且使xhtml代码减小,促进了代码重用、更加的优化。
这一方法的原理,主要是应用CSS的expression,关于expression的更多介绍,请看这篇文章。我们看下面的CSS代码:
ExampleSourceCode
input{star:expression( onmouseover=function(){this.style.borderColor="#060"}, onmouseout=function(){this.style.borderColor="#c00"})}
上面的代码,声明了,当鼠标移上去的时候,边框的颜色是#060,当鼠标移除的时候边框的颜色是#c00。我们看一下运行效果:
SourceCodetoRun
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Strict//EN" "Http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> <head> <metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> <title>52css.com</title> <styletypestyletype="text/css"> <!-- input{border:1pxsolid#c00;} input{star:expression( onmouseover=function(){this.style.borderColor="#060"}, onmouseout=function(){this.style.borderColor="#c00"})} --> </style> </head> <body> 姓名:<inputtypeinputtype="text"/><br/> 年龄:<inputtypeinputtype="text"/><br/> 性别:<inputtypeinputtype="text"/><br/> 手机:<inputtypeinputtype="text"/><br/> 地址:<inputtypeinputtype="text"/><br/> </body> </html>
[可先修改部分代码再运行查看效果]
在定义输入框input样式悬停交互效果的同时,你可以单独的为input输入框另外定义class类,用类与expression同时控制input输入框。更多的东西需要你自己多思考,多试验了。:)
到此,关于“CSS怎么控制input样式和悬停交互”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!
--结束END--
本文标题: CSS怎么控制input样式和悬停交互
本文链接: https://lsjlt.com/news/65841.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0