繁体   English   中英

jQuery UI 可调整大小 - 调整表列大小并溢出

[英]jQuery UI resizable - resize table columns size with overflow

我有一个带有可调整大小列的表,该列是使用 jQuery UI Resizable 实现的。 一切正常,除了我无法更改比内容窄的列大小。 我不能使用表格布局规则,因为在该规则之后表格不能超过 window 大小。 如何解决这个问题?

 $(function () { $("table th").resizable({ minWidth: 100, resize: function (event, ui) { const sizerID = "#" + $(event.target).attr("id"); const { width } = ui.size; $(sizerID).children("span").width(width); } }); });
 .table-holder { overflow: auto; }.table thead span { display: block; }.table tbody tr td { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
 <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.css"> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script> <div class="table-holder"> <table class="table table-bordered table-striped"> <thead> <tr> <th id="Company"><span>Company</span></th> <th id="Contact"><span>Contact</span></th> <th id="Country"><span>Country</span></th> </tr> </thead> <tbody> <tr> <td>Alfreds Futterkiste</td> <td>Maria Anders</td> <td>Germany</td> </tr> <tr> <td>Centro comercial Moctezuma</td> <td>Francisco Chang</td> <td>Mexico</td> </tr> <tr> <td>Ernst Handel</td> <td>Roland Mendel</td> <td>Austria</td> </tr> <tr> <td>Island Trading</td> <td>Helen Be.nett</td> <td>UK</td> </tr> <tr> <td>Laughing Bacchus Winecellars</td> <td>Yoshi Tannamuri</td> <td>Canada</td> </tr> <tr> <td>Magazzini Alimentari Riuniti</td> <td>Giovanni Rovelli</td> <td>Italy</td> </tr> </tbody> </table> </div>

Codepen demo https://codepen.io/DenisDov/pen/WNwodEe

为什么溢出:隐藏在 <td> 中不起作用? 问题不在于调整大小,而在于 TD 元素的性质。 它们继承 Table-Cell 属性而不是 Block 属性,因此您不能以相同的方式重新排列内容。

正如线程中的一些建议,您可以用 DIV 元素包装单元格内容并溢出它。 这是您的代码示例。

 $(function() { $(".table th").resizable({ minWidth: 100 }); });
 .table-holder { overflow: auto; }.table thead span { display: block; width: 100%; }.table tbody tr td div { display: inline-block; white-space: nowrap; position: relative; /* must be relative */ width: 100%; /* fit to table cell width */ margin-right: -1000px; /* technically this is a less than zero width object */ overflow: hidden; }
 <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.css"> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script> <div class="table-holder"> <table class="table table-bordered table-striped"> <thead> <tr> <th id="Company"><span>Company</span></th> <th id="Contact"><span>Contact</span></th> <th id="Country"><span>Country</span></th> </tr> </thead> <tbody> <tr> <td> <div>Alfreds Futterkiste</div> </td> <td> <div>Maria Anders</div> </td> <td> <div>Germany</div> </td> </tr> <tr> <td> <div>Centro comercial Moctezuma</div> </td> <td> <div>Francisco Chang</div> </td> <td> <div>Mexico</div> </td> </tr> <tr> <td> <div>Ernst Handel</div> </td> <td> <div>Roland Mendel</div> </td> <td> <div>Austria</div> </td> </tr> <tr> <td> <div>Island Trading</div> </td> <td> <div>Helen Be.nett</div> </td> <td> <div>UK</div> </td> </tr> <tr> <td> <div>Laughing Bacchus Winecellars</div> </td> <td> <div>Yoshi Tannamuri</div> </td> <td> <div>Canada</div> </td> </tr> <tr> <td> <div>Magazzini Alimentari Riuniti</div> </td> <td> <div>Giovanni Rovelli</div> </td> <td> <div>Italy</div> </td> </tr> </tbody> </table> </div>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM