解决extjs中window拖动时控件透明的现象

本文介绍了解决使用ExtJS开发时窗口拖动出现透明现象的问题,通过修改Ext.Window.DD的startDrag和endDrag函数,移除Ext.Fx的ghost方法,实现了窗口拖动无蒙板的效果。

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

今天extjs开发时,出现window拖动时出现透明的现象,网上找了很久终于找到了解决方法:
现引用如下:

该效果为ExtJS默认效果。 Ext的window之所以在拖拽的时候里头的控件会被蒙上,是因为window继承了标准的DD,在startDrag和endDrag函数当中加上了Ext.Fx的ghost方法的缘故。Ext.Fx是管理元素的动画效果的,ghost方法的作用是滑动淡出,详细看手册。只要把这两句话改掉就能实现window拖动无蒙板。在onReady函数前添加以下代码:

Ext.override(Ext.Window.DD,{ 
  startDrag : function(){ 
     var w = this.win; 
     this.proxy = w.getEl(); 
     if(w.constrain !== false){ 
         var so = w.el.shadowOffset; 
         this.constrainTo(w.container, {right: so, left: so, bottom: so}); 
     }else if(w.constrainHeader !== false){ 
        var s = this.proxy.getSize(); 
         this.constrainTo(w.container, {right: -(s.width-this.headerOffsets[0]), bottom: -(s.height-this.headerOffsets[1])}); 
     } 
   }, endDrag : function(e){ 
     this.win.saveState(); 
   } 
}); 

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值