簡體   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