首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jquery height()问题

jquery height()问题
EN

Stack Overflow用户
提问于 2010-07-19 01:00:34
回答 3查看 6.1K关注 0票数 1

这让我抓狂,谁来帮帮忙,因为我似乎看不出问题出在哪里。

代码语言:javascript
复制
<div id="parent">
   <div id="child"></div>
</div>
<script>
   $('#parent').height(300)

   $('#child').height($('#child').parent().height()-10); //EDITTED LINE
</script>

以上就是我需要做的逻辑。我检查了html标签"#parent“,它说style="height: 300px;”但是孩子的值是-10 :(应该是290;我已经检查了DOM,这个值是正确的,我也尝试过.css('height'),但是没有成功。有没有人遇到过这样的问题?如果有,解决方法是什么:)请帮我走出误区

对不起,伙计们,问题出在"parent().height()“。再次查看脚本(再次抱歉)

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-07-19 01:09:47

.height()有时会获取附加了'px‘的文件。您必须删除'px',否则您将执行'300px' - 10。您可以通过以下方式完成此操作:

代码语言:javascript
复制
var height = parseInt($('#el').height(),10);

将其转换为数字。

因此,您的代码应该从以下更改:

代码语言:javascript
复制
$('#child').height($('#child').parent().height()-10);

至:

代码语言:javascript
复制
$('#child').height(parseInt($('#child').parent().height(),10)-10);

或者更好的是,将缓存添加到代码中以使其更快!(您不必重新获取#child。)

代码语言:javascript
复制
var $child = $('#child');
$child.height(parseInt($child.parent().height(),10)-10);

你也在你的第一行代码中忘记了一个分号,但是我是不相关的。

票数 3
EN

Stack Overflow用户

发布于 2010-07-19 01:07:06

尝试在创建变量之前

代码语言:javascript
复制
var childheight = $('#parent').height()-10;
$('#child').height(childheight);
票数 0
EN

Stack Overflow用户

发布于 2010-07-19 01:02:14

为什么不直接设置为290呢?

代码语言:javascript
复制
$('#child').height(290);
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3276423

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档