html中自适应表格的问题 *** 作方法:
1、实例代码如
<body style="scroll:no"><table width="100%" height="100%">
<tr>
<td height="10px" id="conditions"></td>
</tr>
<tr>
<td id="Content"></td>
</tr>
<tr>
<td height="10px" id="btns">
<input type="button" id="btnDel" value="删除" />
</td>
</tr>
</table>
</body>
2、实例代码如图:
3、代码各个用处分析:
这个表格分为3块
第一个id为conditions,放查询条件。
第二个id为Content,放显示内容。
第三个id为btnDel,放删除按钮。
第一个和第三个宽度可以设置小一点,让内容自己去展开。
一、使用textarea标签进行多行文本的输入有很多限制,比如不能实现高度自适应,会出现难看的滚动条等问题。HTML5中添加了一个新属性contenteditable,该属性可以让input,textarea以外的不可编辑的标签具备可编辑功能;
用法如下:
//contenteditable="true"当属性值为true的时候,可编辑标签内可以写入标签,对于复制的具有样式的内容,其样式会保留;
<div contenteditable="true">我是可编辑的富文本框</div>
//contenteditable="plaintext-only"当属性值为plaintext-only时,该可编辑标签内只能写入纯文本的数据,对于复制的具有样式的内容,会转换为纯文本,而将样式标签等内容过滤掉;
<div contenteditable="plaintext-only"></div>
二、如果不使用该属性,可以使用js控制textarea的高度;原理是当textarea出现滚动条时,增加其高度,使滚动条消失。
怎样判断是否出现滚动条,其方法是但元素的scrollHeight大于offsetHeight的时候,即出现了滚动条;
实现方法如下:
//html
<textarea id="text"></textarea>
//css
#text{
font-size: 20px
overflow: hidden//必须
}
//js
$('#text').on('input',function(){
if(text.scrollHeight>text.offsetHeight){
THeight += 20//font-size的大小是20,因此每次给textarea的高度增加20px
$('#text').css('height',THeight)
}
})
可支持IE6+,firefox,chrome。其中容易被忽略的是<DOCTYPE HTML PUBLIC "-//W3C//DTDHTML 4.0 Transitional//EN">
,不能使用XHTML
<DOCTYPE HTML PUBLIC "-//W3C//DTDHTML 4.0 Transitional//EN">
<html>
<HEAD>
<title>table布局中自适应高度的解决办法</title>
<style type="text/css">
html,body{height:100%font-size:12px}
td {border:1px solid redfont-size: 12pxcolor: #000000margin-left: 0pxmargin-top: 0pxmargin-right: 0pxmargin-bottom: 0px}
#main{border:1px solid redwidth:100%min-height:100%height:100%overflow:hidden !importantoverflow: visible}
#header{height:94pxborder:1px solid red}
</style>
</head>
<body>
<table id="main">
<tr><td id="header">我的顶部</td></tr>
<tr><td>我是主要内容</td></tr>
</table>
</body>
</html>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)