gpt4 book ai didi

html - 具有最大宽度百分比的响应列

转载 作者:搜寻专家 更新时间:2023-10-31 21:49:36 24 4
gpt4 key购买 nike

我需要的非常简单,或者至少应该是这样,但经过几天的研究,我开始求助于 stackoverflow 上询问是否有人真的知道如何做到这一点......

我有 3 列内容,所有内容都包含可扩展内容。内容都不是很广泛,但很丰富(一旦展开)。我需要这样做,以便当您扩展一列中的内容时,它会将其他两列缩小到一定数量,并且当您扩展两列的内容时,它会变平等等。然后,列必须有一个百分比最大大小和最小大小(百分比或静态),这样当列扩展时它们不会完全挤压其他列,这样我就可以为每列设置最大“可扩展性”。为简单起见,这里有一个示例,如果它有效,完成此操作:

<table width="100%"><tr>
<td style="min-width:200px; max-width:60%;">Col1ExpandableContent</td>
<td style="min-width:200px; max-width:50%;">Col2ExpandableContent</td>
<td style="min-width:200px; max-width:40%;">Col3ExpandableContent</td>
</tr></table>

上面的代码当然是行不通的,但我相信你可以想象如果它行得通会怎样。这正是我所需要的,只是出于某种原因,最大宽度不适用于 TD 上的百分比。如果您需要更好的可视化效果,我做了一个 fiddle 来帮助说明这里的问题:http://jsfiddle.net/m5xgcf3s/

由于内容的性质,我不能只使用列的最小宽度,它们都需要可扩展,但只能扩展一定数量。我对任何解决方案和任何方式都持开放态度,它不需要是一个表格(只是默认情况下表格中的 TD 宽度和对齐方式是完美的,如果它支持最大宽度百分比)或任何东西,只要它满足要求并且不使用框架(希望无论如何都不需要)。如果它根本不使用 javascript,那么奖励,但是如果你找到一个允许平滑的动画大小过渡同时仍然满足要求的解决方案,那么你将获得巨大的奖励。如果你能向我解释为什么 max-width percentage 对 table cells 不起作用,还有奖金......







感谢大家的帮助,但我自己编写了一个脚本来解决它...没有框架,没有 jQuery,没有 hack,只需给 TDs 一个 id 并输入这段代码;

<script type="text/javascript">
window.onresize=function setTDmaxwidth() {
var containerwidth = window.innerWidth;
if (containerwidth >= 400 ) {
document.getElementById("col1").style.maxWidth=( ( containerwidth * 0.6 )+'px');
document.getElementById("col2").style.maxWidth=( ( containerwidth * 0.5 )+'px');
document.getElementById("col3").style.maxWidth=( ( containerwidth * 0.4 )+'px');
} else { }
}
</script>

它通过每次容器大小变化时计算容器宽度的分数来模拟最大宽度百分比(在这种情况下,容器是 iframe 宽度的 100%)。我会留下未回答的问题,但万一有人提出另一个答案(有或没有表格),希望是允许宽度过渡动画的答案,或者关于为什么最大宽度百分比对 TDs 不起作用的有效解释

最佳答案

你能试试吗?

我只保留了一个 tr td 的例子。

您必须为这种情况执行每个功能。

试试吧,你会有一些想法..

CSS

    <style type="text/css">
td { border: 1px solid black; }

</style>

脚本

    <script>
function onLoadFunction(){
if(($(".tdFirst div").text().length)<100){
$(".tdFirst div").css('width','200px'); // min width
} else if(($(".tdFirst div").text().length)>=400) {
$(".tdFirst div").css('width','400px'); //max width
} else {
$(".tdFirst div").css('width',$(".tdFirst div").text().length+'px'); //width auto adjust
}
}
</script>

HTML

    <body onLoad="onLoadFunction()">
<table>
<tr>
<td align="center"class="tdFirst">
<div>
Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test Test
</div>
</td>
<td><p>testing...</p></td>
</tr>
</table>
</body>

尝试#2

脚本在你的 fiddle 中使用 jQuery

    $('document').ready(function(){
$(".tdFirst div").each(function(){
if(($.trim($(this).text()).length)<50){
$(this).css('width','20px'); // min width
} else if(($.trim($(this).text()).length)>=60) {
$(this).css('width','60px'); //max width
} else {
$(this).css('width',$.trim($(this).text()).length+'px'); //width auto adjust
}
});
});

关于html - 具有最大宽度百分比的响应列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25718905/

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