Javascript -如何正确调用函数
Javascript - how to call function correctly
我真的不明白如何在文档就绪时正确调用Javascript函数。我的目标是根据浏览器窗口的高度来调整div的大小,我从另一个答案中获得了这段代码。我做错了什么?
function resizeElementHeight(element) {
var height = 0;
var body = window.document.body;
if (window.innerHeight) {
height = window.innerHeight;
} else if (body.parentElement.clientHeight) {
height = body.parentElement.clientHeight;
} else if (body && body.clientHeight) {
height = body.clientHeight;
}
element.style.height = ((height - element.offsetTop) + "px");
}
$(document).ready(resizeElementHeight($('#global_image')));
我试图调用的元素具有id"global_image",但我得到"无法设置未定义的属性高度",我感到迷失在如何为函数提供正确的元素。谢谢你的帮助!
ready()
期望函数作为其参数。现在,您正在调用resizeElementHeight()
并将其返回值传递给ready()
。
在您当前的代码中,在调用resizeElementHeight()
时DOM还没有准备好,元素#global_image
还没有在DOM树中。
应该改成:
$(document).ready(function() {
resizeElementHeight($('#global_image'));
});
resizeElementHeight函数需要dom元素,而不是JavaScript对象。要扩展techfoobar的答案,您应该将其更改为:
$(document).ready(function() {
resizeElementHeight($('#global_image')[0]);
});
调用resizeelementtheight时,DOM对象没有完全加载。替换为is:
$(document).ready(function() {
resizeElementHeight($('#global_image')[0]);
});
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量