当前位置:  开发笔记 > 编程语言 > 正文

隐藏整个表会调整它的大小

如何解决《隐藏整个表会调整它的大小》经验,为你挑选了1个好方法。

有一个带有简单表格的HTML页面和要显示/隐藏的js代码:



    title
    




[click]

s d a

会发生什么事情是在Mozilla上,在您单击两次后(即使使用table-layout:fixed css),表格也会调整大小.IE运行正常.



1> cletus..:

表不应设置为display: block.表行和单元格也不应该.它们具有不同的显示值.我的建议?不要这样做.使用课程:

.hidden {
  display: none;
}

并动态添加它并从表中删除它,以避免在您显示的元素上设置正确的显示类型的问题.

编辑:澄清关于为什么这样做以及发生了什么的评论.试试这个:

Cell 1 Cell 2

它会(或应该)搞砸你的桌面布局.为什么因为默认情况下元素display: table-cell没有block.表格是一样的.他们有display: table.

取消设置CSS属性是有问题的.

因此,您最好使用类来设置和取消设置属性.它更容易更改(该类驻留在CSS文件中而不是代码),避免了将值设置回正确的原始值等问题,并且通常提供更清晰的解决方案,尤其是在与jQuery等库一起使用时.在jQuery中,您可以:

$("table").toggleClass("hidden");

完成.

或者你可以使用addClass(),removeClass()如果这更合适.例如:


...

...

$(function() {
  $("#hide").click(function() {
    if ($("#mytable").is(".hidden")) {
      $("#hide").val("Hide Table");
      $("#mytable").removeClass("hidden");
    } else {
      $("#hide").val("Show Table");
      $("#mytable").addClass("hidden");
    }
  });
});

而且你有一个健壮,简洁和易于理解的解决方案(一旦你了解jQuery语法,这不需要那么长时间).

用Javascript直接搞乱是2002年.:-)

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