首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mootools squeezebox处理程序正在删除隐藏的div元素

Mootools squeezebox处理程序正在删除隐藏的div元素
EN

Stack Overflow用户
提问于 2012-03-13 02:25:26
回答 2查看 1.5K关注 0票数 0

隐藏的div元素内容在第一次弹出模式显示后被删除。

使用下面的处理函数,模态可以很好地显示隐藏的div,然后在清除模态之后,对下面的处理函数的后续调用将返回"Target不存在“的警告,并且隐藏的dive元素实际上已经消失了。

代码语言:javascript
复制
function OnSubmitHandler() {    
if (e = $('modalcontainer')) {
    SqueezeBox.initialize({
        size : {x : 300, y : 120}
    });
    SqueezeBox.open(e, {
        handler : 'adopt',
        overlayOpacity : 0.7,
        onOpen : function(){
            e.style.display = 'block';
        },
        onClose : function(){
            e.style.display = 'none';
        }
    });
}else{
    alert('Target does not exist');
}
}

这应该很简单,并且处理程序函数按照编写的方式工作得很好,但是隐藏的div内容在第一次显示后就消失了。找不到原因。我一定漏掉了什么。

EN

回答 2

Stack Overflow用户

发布于 2012-03-13 04:32:16

因为您adopt了内容,所以它会在DOM中移动到您的挤压框中。由于您不会重用squeezebox实例并每次都对其进行初始化,因此在下一次初始化时,它将清空内容区域(仍然包含e),并且没有其他可采用的内容区域。

重新使用该实例或查看它是否支持克隆。您还可以将e移回dom,甚至只是作为引用onClose - do e.dispose()来保护它。然后执行e = e || $(),但将其保留为作用域变量,而不是全局变量

票数 2
EN

Stack Overflow用户

发布于 2012-11-20 19:04:19

变化

代码语言:javascript
复制
if (e = $('modalcontainer')) {

代码语言:javascript
复制
var e = $('modalcontainer'); 
var e = e.clone(); 
if (e) {

通过这种方式,您可以创建希望显示的元素的精确副本(保留克隆的id ),然后采用处理程序将在关闭时为您处理克隆,因此您不必担心内存泄漏。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9672642

复制
相关文章

相似问题

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