css 表单

一个表单案例,我们使用 css 来渲染 html 的表单元素:

css 实例

input[type=text], select {width: 100%;padding: 12px 20px;margin: 8px 0;display: inline-block;border: 1px solid #ccc;border-radius: 4px;box-sizing: border-box;}input[type=submit] {width: 100%;background-color: #4caf50;color: white;padding: 14px 20px;margin: 8px 0;border: none;border-radius: 4px;cursor: pointer;}input[type=submit]:hover {background-color: #45a049;}div {border-radius: 5px;background-color: #f2f2f2;padding: 20px;}

尝试一下

输入框(input) 样式

使用 width 属性来设置输入框的宽度【attitudes】:

css 实例

input {width: 100%;}

尝试一下

以上实例中设置了所有【all】 <input> 元素的宽度【attitudes】为 100%,如过你只想设置指定类型的输入框可以【 kě yǐ】使用以下属性选择器:

  • input[type=text] - 选取文本输入框
  • input[type=password] - 选择密码的输入框
  • input[type=number] - 选择数字的输入框
  • ...

输入框填充

使用 padding 属性可以【 kě yǐ】在输入框中添加内边距。

css 实例

input[type=text] {width: 100%;padding: 12px 20px;margin: 8px 0;box-sizing: border-box;}

尝试一下

注意我们设置了 box-sizing 属性为border-box。这样可以确保浏览器呈现出带有指定宽度和高度的输入框是把边框和内边距一起【with】计算进去的。
更多内容可以阅读 css3 框大小


输入框(input) 边框

使用 border 属性可以修改 input 边框的大小或颜色,使用 border-radius 属性可以给 input 添加圆角:

css 实例

input[type=text] {border: 2px solid red;border-radius: 明晚开什么特马4px;}

尝试一下

如果你只想添加底部边框可以使用 border-bottom 属性:

css 实例

input[type=text] {border: none;border-bottom: 2px solid red;}

尝试一下

输入框(input) 颜色

可以使用 background-color 属性来设置输入框的背景颜色,color 属性用于修改文本颜色:

css 实例

input[type=text] {background-color: #3cbc8d;color: white;}

尝试一下

输入框(input) 聚焦

默认情况下,一些浏览器在输入框获取焦点时(点击输入框)会有一个蓝色轮廓。我们可以设置 input 样式为 outline: none; 来忽略该效果。

使用 :focus 选择器可以设置输入框在获取焦点时的样式:

css 实例

input[type=text]:focus {background-color: lightblue;}

尝试一下

css 实例

input[type=text]:focus {border: 3px solid #555;}

尝试一下

输入框(input) 图标

如果你想在输入框中添加图标,可以使用 background-image 属性和用于定位的background-position 属性。注意设置图标的左边距,让图标有一定的空间:

css 实例

input[type=text] {background-color: white;background-image: url('searchicon.png');background-position: 10px 10px;background-repeat: no-repeat;padding-left: 40px;}

尝试一下

带动画的搜索框

以下实例使用了 css transition 属性,该属性设置了输入框在获取焦点时会向右延展。你可以在 css 动画 章节查看更多内容。

css 实例

input[type=text] {-webkit-transition: width 0.4s ease-in-out;transition: width 0.4s ease-in-out;}input[type=text]:focus {width: 100%;}

尝试一下

文本框(textarea)样式

注意: 使用 resize 属性来禁用文本框可以重置大小的功能(一般拖动右下脚可以重置大小)。

css 实例

textarea {width: 100%;height: 150px;padding: 12px 20px;box-sizing: border-box;border: 2px solid #ccc;border-radius: 4px;background-color: #f8f8f8;resize: none;}

尝试一下

下拉菜单(select)样式

css 实例

select {width: 100%;padding: 16px 20px;border: none;border-radius: 4px;background-color:
对于整?惴桨钢校?鏊?定保监会与银监会,却不包含证监会的疑问,全国政协委员、全国社保基金理事会会长楼继伟表示,银行、保险行业的监管比较类似,例如都看重机构的资本适足率、偿付能力以及自身风险控管能力等要求
相关措施涵盖?b业、财税、用地、金融、就业、教育【education】、文化、医疗等多个领域,内容非常务实,给了台胞们一个非常好的待遇
电价费率审议会今(16)日召开,外界预期,预估最多涨3%,对科技产业而言,恐增加成本【cost】压力
如今,霍金的微博最后一条停留在2017年11月24日,他在这条微博上称TFBOYS成员王俊凯,
专项培训,计划【plan】全年培训职业院校校长1000人、骨干教师2000人,中小学校【school】长2000人、骨干教师5000人
根据《联合报》报导,上海华东师大学企业【business】管理【guǎn lǐ】系台籍教授陈弘信表示,由于【yóu yú】去年反应热烈,受到官方肯定,今年有了官方支持【support】,交流规模会进一步扩大,预计协助150人交流媒合,合作【hé zuò】的大学也不只限上海市,而是延伸到江苏、浙江【zhè jiāng】境内的学校【school】
陆委会说,台湾实施民主自由制度,由人民选出国家领导人及民意代表,并有充分监督政策推动的机制,国际社会咸认为是华人世界【shì jiè】的民主典
#f1f1f1;}

尝试一下

按钮样式

css 实例

input[type=button], input[type=submit], input[type=reset] {background-color: #4caf50;border: none;color: white;padding: 16px 32px;text-decoration: none;margin: 4px 2px;cursor: pointer;}/* 提示: 使用 width: 100% 设置全宽按钮 */

尝试一下

更多内容可以参考我们的 css 按钮 教程。


响应式表单

响应式表带可以根据浏览器窗口的大小重新布局各个元素,我们可以通过重置浏览器窗口大小来查看效果:

高级: 以下实力使用了css3 多媒体查询 来创建一个响应式表单。

css 实例

* {box-sizing: border-box;}input[type=text], select, textarea {width: 100%;padding: 12px;border: 1px solid #ccc;border-radius: 4px;resize: vertical;}label {padding: 12px 12px 12px 0;display: inline-block;}input[type=submit] {background-color: #4caf50;color: white;padding: 12px 20px;border: none;border-radius: 4px;cursor: pointer;float: right;}input[type=submit]:hover {background-color: #45a049;}.container {border-radius: 5px;background-color: #f2f2f2;padding: 20px;}.col-25 {float: left;width: 25%;margin-top: 6px;}.col-75 {float: left;width: 75%;margin-top: 6px;}/* 清除浮动 */.row:after {content: "";display: 开什么特马table;clear: both;}/* 响应式布局 layout - 在屏幕宽度小于 600px 时, 设置为上下堆叠元素 */@media screen and (max-width: 600px) {.col-25, .col-75, input[type=submit] {width: 100%;margin-top: 0;}}

尝试一下