gpt4 book ai didi

css - 当 Firefox 4 报告表格单元格的 offsetWidth 不一致时的解决方法是什么

转载 作者:行者123 更新时间:2023-11-28 14:38:08 24 4
gpt4 key购买 nike

我有一个甘特图类型的 Web 控件:一个 html 单元格表(例如,一个单元格代表一天)和一些绝对定位的 div 代表条形图 - div 的父元素是适当的开始 TD。我设置了 div 的宽度,以便它们覆盖适当的天数。宽度是通过对 div 覆盖的单元格的 offsetWidth 值求和来计算的。

这在 IE7、Chrome 和 Opera(我认为在 Firefox 2)中正常工作,但在 Firefox 4 中不正常。 div 的长度有时太短有时太长。从调查问题来看,它似乎与类似于 that described here 的子像素问题有关。

我看到的(参见下面的源 html)是我的 100% 宽表格(它的 offsetWidth 报告为 1311 px)被分成 30 个单元格,平均应该占用 43.7 px。显然它必须使用整数,但 Firefox 4 报告每个单元格都有一个 offsetWidth = 44 像素,因此对于覆盖每个单元格的 div,它的 offsetWidth 是 1320 像素(9 像素到大)。显然,该表保留其 1311 像素的宽度,表明单元格 offsetWidth 可能报告 44,而在某些情况下单元格实际占用 43 像素

与 chrome、opera 和 IE7 相比,单元格的 offsetWidth 是 44 和 43 像素的混合,但加起来正确的最终宽度为 1311。

问题是我如何解决 Firefox4 的这种行为以确保我的 div 具有正确的长度。

我还没有在其他版本的IE上测试过

这是该问题的一个简化工作示例:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head id="Head1">
<title>Planner Test</title>
<style type="text/css">

body
{
font-size:10px;
}
table
{
width:100%;
border-collapse:collapse;
border-spacing:0px;
table_layout:fixed;
margin: 0px 0px 0px 0px;
padding: Opx 0px 0px 0px;

}

table td,
table th
{
overflow: hidden;
vertical-align:top;
height:19px;
border:1px solid red;
padding: 0px 0px 0px 0px;
margin: 0px 0px 0px 0px;
}

div.PlannerItem
{
text-align:right;
overflow: hidden;
position:absolute;
height:16px;

border: solid 0px black;
background-color: yellow;
color: #334575;
padding: 0px 0px 0px 0px;
margin: 0px 0px 0px 0px;
}

</style>
<script type="text/javascript">
//<![CDATA[

function WIDTH( el ) {
// use offsetWidth - supposed to be most consistent accross browsers
return parseInt( el.offsetWidth );
}

function createRows()
{
var nbCells = 30; // set to vary the number of cells

var thead = document.getElementById( "tablehead" );
var fragment = document.createDocumentFragment();
var row = document.createElement( "tr" );
var th;

// create header row % width calculated from nbCells
for( i = 0; i < nbCells; i++ ) {
th = document.createElement( "th" );

th.style.width = (100.0 / nbCells) + "%";
row.appendChild( th );
}
fragment.appendChild(row);
thead.appendChild(fragment );

// body rows
var tbody = document.getElementById( "tablebody" );

for ( i = 0; i < nbCells; i++ ) {
fragment = document.createDocumentFragment();
row = document.createElement("tr");
for ( j = 0; j < nbCells; j++ ) {
var cell = document.createElement( "td" );
if ( j == 0 ) {
var div = document.createElement("div");
div.className = "PlannerItem";
cell.appendChild( div );
}
row.appendChild( cell );
}

fragment.appendChild(row );
tbody.appendChild( fragment );
}

setWidths();

}
function setWidths()
{
var rows = document.getElementsByTagName( "tr" );

// show cell widths in header
cells = rows[0].getElementsByTagName( "th" );
for( i = 0; i < cells.length; i++ ) {
cells[i].innerHTML = WIDTH(cells[i]);
}

// calculate widths for divs
for( i = 1; i < rows.length; i++ ) {
var cells = rows[i].getElementsByTagName( "td" );
var width = 0;
var div = cells[0].firstChild;
for( j = 0; j < i; j++ ) {

width += parseInt( WIDTH( cells[j]) );

}

div.style.width = width + "px";
div.innerHTML = WIDTH(div);
}
}//]]>
</script>

</head>
<body onload='createRows();'>
<form id="form1" runat="server" >
<table id="tab">
<thead id="tablehead">
</thead>
<tfoot></tfoot>
<tbody id='tablebody'></tbody>
</table>
</form>
</body>
</html>

最佳答案

看起来使用 getBoundingClientRec() 而不是 offsetWidth(参见 http://weblogs.mozillazine.org/roc/archives/2008/01/subpixel_layout.html)解决了问题 - 需要使用此值计算 div 宽度以免丢失精度:在这种情况下 div 与单元格正确对齐

关于css - 当 Firefox 4 报告表格单元格的 offsetWidth 不一致时的解决方法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6457265/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com