匿名函数里的对象,跟定义匿名函数页面的上下文有关,而与调用匿名函数的页面无关。
很拗口。举例说明:
//在某个“容器”页面
<div id="map_workspace"></div>
<script> function showWorkSpace(callback, h) {
var height = 500; callback("map_workspace",height); } </script>
//在该“容器”页面中的某个iframe页面
<script> parent.showWorkSpace(function (containerId, h) {
var container = $("#" + containerId); container.empty().html("<iframe class='frame frameMap' style='width:100%;height:" + h + ";' src='" + url + "'></iframe>"); }); </script>
匿名函数在iframe里定义,而在“容器”页面执行,而$(“#map_workspace”)对象很明显在“容器”页面上,但偏偏,没有获得我们预期的结果。改为:
//在某个“容器”页面
function showWorkSpace(callback, h) {
var height = 500;
callback($("#map_workspace"),height);
}
//在该“容器”页面中的某个iframe页面
parent.showWorkSpace(function (container, h) {
container.empty().html("<iframe class='frame frameMap' style='width:100%;height:" + h + ";' src='" + url + "'></iframe>");
});
效果如愿。
什么道理,我也说不上来,仅作记录。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/189143.html原文链接:https://javaforall.cn
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有