Firefox中 TEXTAREA 元素的 rows 属性很奇怪

探讨了TEXTAREA元素在不同浏览器中的表现差异,特别是在Firefox中设置rows属性时出现的经典Bug,并对比了其与其他浏览器的行为差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TEXTAREA 对于交互来说,它的地位无可替代。相信很少人不知道怎么设置TEXTAREA 可显示文字的行数和列数吧?TEXTAREA 可以通过设置 rows 或 cols 属性分别设置可显示文字的行数和列数。

那么,各浏览器是否对这个简单的属性有一致的表现呢?

答案是否定的……

Firefox很奇怪
问题代码:


<textarea rows="0">1
2
3</textarea>
<textarea rows="1">1
2</textarea>
<textarea rows="5">1
2
3
4
5
6</textarea>


这段代码很简单,但是需要注意,第一个文本数字和 TEXTAREA 标签之间没有空格和回车,最后一个数字和 TEXTAREA 之间也没有回车和空格,这个设置是为了查看方便。

在各浏览器中打开,截图如下:
Firefox中:

IE和其他浏览器中:


从截图中很明显地看出,Firefox中,TEXTAREA均比其他浏览器多一行,且当rows属性不存在或者为非自然数时,各浏览器对rows属性的默认值均是2,Firefox则正好多一行为3。总是比正常的行数多1。

标准中的 rows
让我们看一下W3C标准中是怎么说的。

rows属性指定了可视文本的行数。用户应该被允许输入更多行的文本,但当内容超出可视区域时,用户端应该为文本内容提供类似滚动机制。
其中明确指出了,是可是文本的行数。

在这里:http://www.w3.org/TR/html401/interact/forms.html#adef-rows-TEXTAREA

这个现象是Firefox的一个经典Bug,已经存在很长时间,参见官方站点说明:https://bugzilla.mozilla.org/show_bug.cgi?id=33654。

解决方案
……,有人有解决方案么?送分送分……

更多兼容性问题:
【分享】浏览器兼容性问题目录

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值