我这样设置后列宽并未改变
时间: 2024-04-14 15:31:01 浏览: 89
23-15透视表刷新时保持列宽不变.avi
非常抱歉之前的回答没有解决你的问题。在你的代码中,我注意到你在删除行或列后尝试重新设置列宽度,但是这种方法不会生效。
要动态调整表格的列宽,可以使用CSS中的`table-layout: fixed;`属性。这样设置后,表格的列宽将会根据表格的宽度和列内容的宽度进行自动调整。
以下是修正后的代码,包括使用`table-layout: fixed;`属性来调整列宽度:
```html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>鉴本</title>
<style>
table {
border-collapse: collapse;
table-layout: fixed; /* 设置表格布局为固定 */
width: 100%; /* 设置表格宽度为100% */
}
td, th {
border: 1.5px solid black;
padding: 5px;
}
table img {
max-width: 150px;
height: auto;
}
.popup {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.8);
display: flex;
align-items: center;
justify-content: center;
}
.popup img {
max-width: 100%;
max-height: 100%;
cursor: zoom-out;
}
</style>
</head>
<body>
<div>
<button onclick="addRow()">新增一行</button>
<button onclick="addColumn()">添加一列</button>
<button onclick="deleteRow()">删除行</button>
<button onclick="deleteColumn()">删除列</button>
<button onclick="changeSize()">调整大小</button>
</div>
<div id="popup" class="popup" style="display: none;">
<img id="popupImg">
</div>
<table id="myTable">
<thead>
<tr>
<th>表头1</th>
<th>表头2</th>
<th>表头3</th>
<!-- 其他表头列 -->
</tr>
</thead>
<tbody>
<tr>
<td>单元格1</td>
<td>单元格2</td>
<td>单元格3</td>
<!-- 其他单元格列 -->
</tr>
</tbody>
</table>
<script>
var table = document.getElementById("myTable");
function addRow() {
var newRow = table.insertRow();
var cellsCount = table.rows[0].cells.length;
for (var i = 0; i < cellsCount; i++) {
var newCell = newRow.insertCell();
newCell.contentEditable = true;
newCell.innerHTML = "新单元格";
}
}
function addColumn() {
var cellsCount = table.rows[0].cells.length;
for (var i = 0; i < table.rows.length; i++) {
var newCell = table.rows[i].insertCell();
newCell.contentEditable = true;
newCell.innerHTML = "新单元格";
}
}
function deleteRow() {
if (table.rows.length > 2) {
table.deleteRow(table.rows.length - 1);
}
}
function deleteColumn() {
if (table.rows[0].cells.length > 1) {
for (var i = 0; i < table.rows.length; i++) {
table.rows[i].deleteCell(table.rows[i].cells.length - 1);
}
}
}
</script>
</body>
</html>
```
在这个修正后的代码中,我将表格的布局属性设置为`table-layout: fixed;`,并将表格的宽度设置为`width: 100%;`。这样,表格的列宽度将会根据表格的宽度和列内容的宽度进行自动调整。
希望这个示例能够解决你的问题。如果还有其他疑问,请随时提问。非常抱歉给你带来了困扰。
阅读全文