天天看点

[Sencha ExtJS6 Modern] 改进bug: 当store.remove/removeAt执行之后,DataView的对应item的dom没有移除

原文地址:http://blog.csdn.net/lovelyelfpop/article/details/51853285

ExtJS 版本:

Ext 6.0.2.437 Modern

描述:

一个dataview,绑定一个store,  执行了store.remove/removeAt方法之后,dataview中的对应item的dom元素并没有移除

预期现象:

被删除的record的对应的dom元素应该要被删除的

此现象可以看这个示例:

https://fiddle.sencha.com/#fiddle/1d7k

原因:

'Ext.dataview.DataView' 类中,方法 'onStoreRemove' 的'indices' 参数实际是个整型, 但是在函数体内却使用了索引,明显不对.

onStoreRemove: function(store, records, indices) {
    var container = this.container,
        ln = records.length,
        i;
    for (i = 0; i < ln; i++) {
        container.moveItemsToCache(indices[i], indices[i]); //这里
    }
},
           

改为:

onStoreRemove: function(store, records, indices) {
    var container = this.container,
        ln = records.length,
        i;
    for (i = 0; i < ln; i++) {
        container.moveItemsToCache(indices + i, indices + i); //这里
    }
},
           

现在可以了,看这个例子:

https://fiddle.sencha.com/#fiddle/1d7n

欢迎加入Sencha Touch + Phonegap交流群

1群:194182999 (满)

2群:419834979

共同学习交流(博主QQ:479858761)