热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

对“设置样式时怎么区分input是按钮还是文本框”问题的技术调查——把input里面的东西剔出来...

当你看到这个html标签的时候,你会想到什么?一个文本框?一个按钮?一个单选框?一个复选框&#x

当你看到这个html标签的时候,你会想到什么?一个文本框?一个按钮?一个单选框?一个复选框?……对,对,对,它们都对。也许你可能想不到,这个小小的input竟然可以创造出10个不同的东西,下面是个列表,看看,哪些是你没有想到的:

  • 文本框
  • 密码框
  • 提交按钮
  • 重置按钮
  • 单选框
  • 复选框
  • 普通按钮
  • 文件选择控件
  • 隐藏框
  • 图片按钮

 所以你可能会说,input真是一个伟大的东西,竟然这么有“搞头”,但是当你真正在项目中试图给不同的控件设置不同的样式时,你就会发现,input真的可以把“你的头搞大”。我不知道为什么当初要给input赋予那么多身份,但是,他的“N重身份”给网站设计者的确带来了不少的麻烦。好在,劳动人民是伟大的,解决问题的办法还是有滴~,虽然它们都有各自致命的缺点 Orz… 解放方法大致归纳一下,列表如下(小弟才疏,错误遗漏难免,还请各位高人指点):

1.用css的expression判断表达式
2.用css中的type选择器
3.用Javascript脚本实现
4.如果你用Microsoft Visual Studio 2005 或者后续版本开发项目,恭喜,你还可以使用skin。

下面就来讲解一下各个办法的详细实现和它们的优缺点。

1:用css的expression判断表达式
实现代码参考:

doctype html public "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns&#61;"http://www.w3.org/1999/xhtml" >
<head>
    
<title> diffInput2 title>
    
<meta name&#61;"Author" content&#61;"JustinYoung"/>
    
<meta name&#61;"Keywords" content&#61;""/>
    
<meta name&#61;"Description" content&#61;""/>
    
<meta http-equiv&#61;"Content-Type" content&#61;"text/html; charset&#61;utf-8"/>
    
<style type&#61;"text/css">
    input
    
{
    background-color
:expression(this.type&#61;&#61;"text"?&#39;#FFC&#39;:&#39;&#39;);
    
}
    
style>
head>

<body>
<dl>
<dt>This is normal textbox:<dd><input type&#61;"text" name&#61;"">
<dt>This is normal button:<dd><input type&#61;"button" value&#61;"i&#39;m button">
dl>
body>
html>

优点&#xff1a;简单&#xff0c;轻量级
缺点&#xff1a;expression判断表达式FireFox是不支持的。致命的是只能区分出一个&#xff08;例如例子中就只能区分出text文本框&#xff09;&#xff0c;不要试图设置多个&#xff0c;下面的会将上面的覆盖掉 Orz…

2&#xff1a;用css中的type选择器
实现参考代码&#xff1a;
doctype html public "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns&#61;"http://www.w3.org/1999/xhtml" >
<head>
    
<title> diffInput2 title>
    
<meta name&#61;"Author" content&#61;"JustinYoung"/>
    
<meta name&#61;"Keywords" content&#61;""/>
    
<meta name&#61;"Description" content&#61;""/>
    
<meta http-equiv&#61;"Content-Type" content&#61;"text/html; charset&#61;utf-8" />
    
<style type&#61;"text/css">
    input[type&#61;"text"]
    
{
    background-color
:#FFC;
    
}
    
    input[type&#61;"password"]
    
{
    background-image
:url(BG.gif);
    
}
    
    input[type&#61;"submit"]
    
{
    background-color
:blue;
    color
:white;
    
}
    
    input[type&#61;"reset"]
    
{
    background-color
:navy;
    color
:white;
    
}
    
    input[type&#61;"radio"]
    
{
    
/*In FF,Some radio style like background-color not been supported*/
    margin
:10px;
    
}
    
    input[type&#61;"checkbox"]
    
{
    
/*In FF,Some checkbox style like background-color not been supported*/
    margin
:10px;
    
}
    
    input[type&#61;"button"]
    
{
    background-color
:lightblue;
    
}
    
style>
head>

<body>
<dl>
<dt>This is normal textbox:<dd><input type&#61;"text" name&#61;"">
<dt>This is password textbox:<dd><input type&#61;"password" name&#61;"">
<dt>This is submit button:<dd><input type&#61;"submit">
<dt>This is reset button:<dd><input type&#61;"reset">
<dt>This is radio:<dd><input type&#61;"radio" name&#61;"ground1"> <input type&#61;"radio" name&#61;"ground1">
<dt>This is checkbox:<dd><input type&#61;"checkbox" name&#61;"ground2"> <input type&#61;"checkbox" name&#61;"ground2">
<dt>This is normal button:<dd><input type&#61;"button" value&#61;"i&#39;m button">
dl>
body>
html>

优点&#xff1a;简单&#xff0c;明了&#xff0c;可以分区出各个input控件形态。
缺点&#xff1a;type选择器&#xff0c;IE6之前的对web标准支持的不太好的浏览器不能支持&#xff08;致命呀 Orz…&#xff09;

3&#xff1a;用Javascript脚本实现
实现参考代码&#xff1a;
前台html代码&#xff1a;
doctype html public "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns&#61;"http://www.w3.org/1999/xhtml" >
<head>
    
<title> diffInput title>
    
<meta name&#61;"Author" content&#61;"JustinYoung">
    
<meta name&#61;"Keywords" content&#61;"">
    
<meta name&#61;"Description" content&#61;"">
    
<meta http-equiv&#61;"Content-Type" content&#61;"text/html; charset&#61;utf-8" >
    
<style type&#61;"text/css">
    input
{behavior:url(&#39;css.htc&#39;);}
    
style>
head>

<body>
<dl>
<dt>This is normal textbox:<dd><input type&#61;"text" name&#61;"">
<dt>This is password textbox:<dd><input type&#61;"password" name&#61;"">
<dt>This is submit button:<dd><input type&#61;"submit">
<dt>This is reset button:<dd><input type&#61;"reset">
<dt>This is radio:<dd><input type&#61;"radio" name&#61;"ground1"> <input type&#61;"radio" name&#61;"ground1">
<dt>This is checkbox:<dd><input type&#61;"checkbox" name&#61;"ground2"> <input type&#61;"checkbox" name&#61;"ground2">
<dt>This is normal button:<dd><input type&#61;"button" value&#61;"i&#39;m button">
dl>
body>
html>

Css.htc代码&#xff1a;
<script language&#61;Javascript>
switch(type)
{
    
case &#39;text&#39;:
    style.backgroundColor
&#61;"red";
    
break;

    
case &#39;password&#39;: 
    style.backgroundImage
&#61;"url(BG.gif)";
    
break;

    
case &#39;submit&#39;:
    style.backgroundColor
&#61;"blue";
    style.color
&#61;"white";
    
break;

    
case &#39;reset&#39;:
    style.backgroundColor
&#61;"navy";
    style.color
&#61;"white";
    
break;

    
case &#39;radio&#39;: 
    style.backgroundColor
&#61;"hotpink";
    
break;

    
case &#39;checkbox&#39;: 
    style.backgroundColor
&#61;"green";
    
break;

    
case &#39;button&#39;:
    style.backgroundColor
&#61;"lightblue";
    
break;

    
default: ;//others use default style.
}
script>

优点&#xff1a;可以分区出各个input控件形态。多种技术的混合使用&#xff0c;满足“我是高手”的虚荣心。
缺点&#xff1a;技术牵扯面教广&#xff0c;因为用js后期处理&#xff0c;所以在js没有起作用之前&#xff0c;各个input还是原始状态&#xff0c;然后突然“变帅”会让你的页面很奇怪。较致命的是FireFox不支持 Orz…

4&#xff1a;Microsoft Visual Studio 2005中使用skin。
Skin文件参考代码&#xff1a;
<%--Style for common TextBox--%>
<asp:TextBox runat&#61;"server" style&#61;"background-color:#FFC ">asp:TextBox>
<asp:Button runat&#61;"server" style&#61;”background-color:red”>asp:Button>


注意里面的样式是用style加上的&#xff0c;而不是用cssClass&#xff0c;道理很简单&#xff0c;如果用cssClass&#xff0c;前面的再用cssClass就会覆盖这个cssClass。导致失败。当然&#xff0c;skin不能单独使用&#xff0c;还要配合css样式表。

优点&#xff1a;可以分区出各个控件形态&#xff08;注意&#xff1a;skin只能对服务器端控件使用&#xff0c;所以现在已经不是单纯的input标签了&#xff0c;虽然这些服务器端控件“打到”前台的时候仍然是input控件&#xff09;。除了css&#xff0c;又被分离一层&#xff0c;使得样式的设置能有更好的定制性。其他优点&#xff08;参考skin的优点&#xff09;。
缺点&#xff1a;只能对服务器端控件使用。不是所有的项目都能使用skin功能 Orz…



总结&#xff1a;上面的方法&#xff0c;都是有各自的优点和缺点&#xff0c;所以单独的使用任何一个都不能很好的解决问题。所以应该将多个方法配合一起使用&#xff0c;这样才能较好的解决问题。但是多个方法配合使用就是完美的了吗&#xff1f;NO&#xff5e;&#xff01;它也有致命的缺点——多套方案的维护需要更大的成本&#xff01;

 

后记&#xff1a;这是一个以IE6为首&#xff0c;非web标准浏览器横扫天下的乱世年代&#xff0c;不知有多少网页初学者惨死在IE6的诡异解析模式之下&#xff0c;又有多少程序员被IE6所奴役&#xff0c;还有无数web设计者在IE6的胯下忍辱偷生。虽然黑暗中我们欣慰的看到FireFox反对暴统的勇者的出现&#xff0c;以及IE7对Web标准越来越好的支持这道曙光。但是黑夜仍旧将会持续很长一段时间。对于web标准一统天下的年代&#xff0c;我们既喜且悲。喜的是&#xff0c;到那个时候&#xff0c;我们做网页设计和规划将会如同吃饭般简单&#xff0c;悲的是&#xff1a;如果真的到了那个时候&#xff0c;我们吃饭的饭碗还能那么重吗&#xff1f;不过&#xff0c;为了人类社会的进步&#xff0c;拯救地球的科技&#xff0c;发展宇宙的技术文化 -_-b… 我依然期待web标准一统天下的到来。



keyword:自动区分各类不同的input样式,在CSS中如何区分,利用Javascript来实现自动区分各类不同的input样式,input,input type,input type file,input type hidden,input file,input.dll,html input,input type image

 

转:https://www.cnblogs.com/JustinYoung/archive/2007/07/19/824502.html



推荐阅读
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • 如何在HTML中获取鼠标的当前位置
    本文介绍了在HTML中获取鼠标当前位置的三种方法,分别是相对于屏幕的位置、相对于窗口的位置以及考虑了页面滚动因素的位置。通过这些方法可以准确获取鼠标的坐标信息。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 如何搭建Java开发环境并开发WinCE项目
    本文介绍了如何搭建Java开发环境并开发WinCE项目,包括搭建开发环境的步骤和获取SDK的几种方式。同时还解答了一些关于WinCE开发的常见问题。通过阅读本文,您将了解如何使用Java进行嵌入式开发,并能够顺利开发WinCE应用程序。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 本文介绍了一种在PHP中对二维数组根据某个字段进行排序的方法,以年龄字段为例,按照倒序的方式进行排序,并给出了具体的代码实现。 ... [详细]
author-avatar
hnzhenlin
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有