当前位置:  开发笔记 > 前端 > 正文

HTML表格中的文本框:如何自动调整大小?

如何解决《HTML表格中的文本框:如何自动调整大小?》经验,为你挑选了2个好方法。

我想在HTML表格的底部(或顶部,无论如何)添加一行,每列中都有一个文本框(以允许过滤每列的内容).

FWIW,该表基于jQuery DataTables插件.

问题是文本框扩大了列.我希望每个文本框都填充其列的宽度而不放大它.我怎样才能做到这一点?



1> ntan..:

尝试获取父td的宽度.


我不完全确定,但我认为这种方法可能存在问题,因为文本框的边框和填充占用了一些加上宽度的文本框.也就是说,如果td是100px宽并且文本框具有1px边框和4px填充,则文本框实际上需要总宽度为100 + 2*(1 + 4)= 110px(如果设置为width =" 100%".我认为.

2> bobince..:

我认为[宽度100%]可能是这种方法的一个问题,因为文本框的边框和填充占用了一些添加到宽度的文本框.

确实.

您可以通过添加padding-right到包含与输入的边界和填充相似大小的输入(或仅对所有单元格)的单元格来补偿这一点.然后输入扩展出单元格内容区域,但只扩展到填充,因此它不会弄乱.

对于普通的文本输入,这没关系.如果您还有其他元素,如选择框或按钮,您希望以这种方式调整大小,填充方法可能适得其反,因为在IE上,选择的"宽度"包括边框和填充(由于是一个操作系统小部件) ).

对于大多数浏览器,最简单和最一致的解决方法是CSS3 box-sizing属性:

td.input input {
    width: 100%;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
}

IE6-7尚不支持此功能,因此您仍然可以获得在这些浏览器中排列不完整的字段.如果您在意,可以专门为这些添加填充解决方法.

推荐阅读
贴进你的心聆听你的世界
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有