jQuery UI可调整大小-使用溢出来调整表列大小

丹尼斯

我有一个带有可调整大小的列的表,该表通过jQuery UI Resizable实现。一切正常,除非我不能更改比内容窄的列大小。我不能使用表格布局规则,因为在那之后规则表不能超过窗口大小。如何解决呢?

$(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 Bennett</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元素的性质。它们继承了表单元属性而不是块属性,因此您不能以相同的方式重排内容。

如线程中建议的那样,您可以使用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 Bennett</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>

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

使用jQuery UI问题使Bootstrap模态可调整大小

jQuery UI可调整大小的两个对象

jQuery UI可调整大小,防止高度小于文本

Jquery UI 可调整大小的处理程序

jquery ui 可调整大小触发 onclick 事件

jQuery UI菜单和可调整大小-重叠

jQuery UI可调整大小和可拖动的问题

如何动态更改jquery ui可调整大小的选项?

jQuery UI可调整大小的自动隐藏句柄

jQuery UI:可调整大小:捕获调整大小事件

jQuery可调整大小的更改css

jQuery可调整大小的奇怪行为

在Angular 6中使用可调整大小的jQuery UI

如何使用jQuery UI动态更改可调整大小元素的句柄

使用遏制时,JQuery-UI可调整大小的顶部和右侧错误

jQuery UI同时使用可调整大小和可拖动

jQuery-可调整大小的UI调整所有子元素的大小及其字体大小

jQuery UI-jQuery可调整大小的保证金问题

在没有jquery UI的div中单击时如何使图像可调整大小

如何在jQuery UI的可调整大小的函数中将aspectRatio选项传递给AlsoResize对象?

jQuery-UI可调整大小的否定位置:固定

jQuery UI:具有滚动条的可调整大小的div

带有空格的 jQuery UI 可调整大小的网格

jQuery UI可调整大小-超出minWidth,maxWidth,minHeight,maxHeight的事件触发器

Jquery-ui 可调整大小的功能无法与 flexbox div 正常工作

Jquery Ui 可调整大小的自定义处理程序不起作用

我需要TH中的可调整大小(jQuery ui)div不要小于TD宽度或使TD溢出:隐藏

使用jQuery可调整大小的处理程序附加和调整div的大小

jQuery可调整大小使我无法编辑div