我在排序ExtJS网格时遇到问题。我正在使用Ext JS版本5.1.1.451。
网格加载良好,但是当我尝试对列进行排序时,我得到“未捕获的TypeError:无法读取属性'isSynchronized'未定义”错误。
方法addCls
是在鼠标移动时触发的,当发生错误时,me.getData()
会返回undefined
,其中me
constructor
$observableInitialized: true
component: constructor
config: Object
destroy: () {}
dom: null
el: null
events: Object
hasListeners: statics.prepareClass.HasListeners
id: "ext-quicktips-tip"
initConfig: () {}
initialConfig: Object
isDestroyed: true
lastBox: null
managedListeners: Array[0]
shadow: null
这是发生错误的addCls
方法:
addCls: function(names, prefix, suffix) {
var me = this,
elementData = me.getData(),
hasNewCls, dom, map, classList, i, ln, name;
if (!names) {
return me;
}
if (!elementData.isSynchronized) {
me.synchronize();
}
以前有人遇到过这个问题吗?这是一个已知问题还是我做错了什么?
谢谢
答案 0 :(得分:0)
我已经覆盖了handleMouseDown方法并注释掉了快速提示部分。
Ext.override(Ext.dd.DragDropManager, {
handleMouseDown: function (e, oDD) {
var me = this,
xy, el;
me.isMouseDown = true;
//if (Ext.quickTipsActive) {
// Ext.tip.QuickTipManager.ddDisable();
//}
me.currentPoint = e.getPoint();
if (me.dragCurrent) {
me.handleMouseUp(e);
}
me.mousedownEvent = e;
me.currentTarget = e.getTarget();
me.dragCurrent = oDD;
el = oDD.getEl();
Ext.fly(el).setCapture();
xy = e.getXY();
me.startX = xy[0];
me.startY = xy[1];
me.offsetX = me.offsetY = 0;
me.deltaX = me.startX - el.offsetLeft;
me.deltaY = me.startY - el.offsetTop;
me.dragThreshMet = false;
}
});
如果有人有更好的答案,请张贴,如果情况好,我会标记。