we54188 2016-12-05 13:34 采纳率: 50%
浏览 1141

【求Ext大神】关于拖动dropZone

问题描述:Ext6拖动后无法获取到目的地的相关属性。

代码:(拿API中的demo举例 - dragdropzones.html)

问:如何在拖动释放鼠标后的 onNodeDrop 监听方法里获取到 hospitals 对象中的属性(如 code、name、address等)? 谢谢!

  • 写回答

2条回答 默认 最新

  • we54188 2016-12-05 13:38
    关注

    【附代码】

    /*

    • Here is where we "activate" the DataView.
    • We have decided that each node with the class "patient-source" encapsulates a single draggable
    • object. *
    • So we inject code into the DragZone which, when passed a mousedown event, interrogates
    • the event to see if it was within an element with the class "patient-source". If so, we
    • return non-null drag data. *
    • Returning non-null drag data indicates that the mousedown event has begun a dragging process.
    • The data must contain a property called "ddel" which is a DOM element which provides an image
    • of the data being dragged. The actual node clicked on is not dragged, a proxy element is dragged.
    • We can insert any other data into the data object, and this will be used by a cooperating DropZone
    • to perform the drop operation. */ function initializePatientDragZone(v) { v.dragZone = Ext.create('Ext.dd.DragZone', v.getEl(), {

    // On receipt of a mousedown event, see if it is within a draggable element.
    // Return a drag data object if so. The data object can contain arbitrary application
    // data, but it should also contain a DOM element in the ddel property to provide
    // a proxy to drag.
    getDragData: function(e) {
    var sourceEl = e.getTarget(v.itemSelector, 10), d;
    if (sourceEl) {
    d = sourceEl.cloneNode(true);
    d.id = Ext.id();
    return (v.dragData = {
    sourceEl: sourceEl,
    repairXY: Ext.fly(sourceEl).getXY(),
    ddel: d,
    patientData: v.getRecord(sourceEl).data
    });
    }
    },

    // Provide coordinates for the proxy to slide back to on failed drag.
    // This is the original XY coordinates of the draggable element.
    getRepairXY: function() {
    return this.dragData.repairXY;
    }
    });
    }

    /*

    • Here is where we "activate" the GridPanel.
    • We have decided that the element with class "hospital-target" is the element which can receieve
    • drop gestures. So we inject a method "getTargetFromEvent" into the DropZone. This is constantly called
    • while the mouse is moving over the DropZone, and it returns the target DOM element if it detects that
    • the mouse if over an element which can receieve drop gestures. *
    • Once the DropZone has been informed by getTargetFromEvent that it is over a target, it will then
    • call several "onNodeXXXX" methods at various points. These include: *
    • onNodeEnter
    • onNodeOut
    • onNodeOver
    • onNodeDrop *
    • We provide implementations of each of these to provide behaviour for these events.
      */
      function initializeHospitalDropZone(v) {
      var gridView = v,
      grid = gridView.up('gridpanel');

      grid.dropZone = Ext.create('Ext.dd.DropZone', v.el, {

    // If the mouse is over a target node, return that node. This is
    // provided as the "target" parameter in all "onNodeXXXX" node event handling functions
    getTargetFromEvent: function(e) {
    return e.getTarget('.hospital-target');
    },

    // On entry into a target node, highlight that node.
    onNodeEnter : function(target, dd, e, data){
    Ext.fly(target).addCls('hospital-target-hover');
    },

    // On exit from a target node, unhighlight that node.
    onNodeOut : function(target, dd, e, data){
    Ext.fly(target).removeCls('hospital-target-hover');
    },

    // While over a target node, return the default drop allowed class which
    // places a "tick" icon into the drag proxy.
    onNodeOver : function(target, dd, e, data){
    return Ext.dd.DropZone.prototype.dropAllowed;
    },

    // On node drop, we can interrogate the target node to find the underlying
    // application object that is the real target of the dragged data.
    // In this case, it is a Record in the GridPanel's Store.
    // We can use the data set up by the DragZone's getDragData method to read
    // any data we decided to attach.
    onNodeDrop : function(target, dd, e, data){
    var rowBody = Ext.fly(target).findParent('.x-grid-rowbody-tr', null, false),
    mainRow = rowBody.previousSibling,
    h = gridView.getRecord(mainRow),
    targetEl = Ext.get(target),
    html = targetEl.dom.innerHTML;

            if (html == 'Drop Patient Here') {
                html = data.patientData.name
            } else {
                html = data.patientData.name + ', ' + targetEl.dom.innerHTML;
            }
    
            targetEl.update(html);
            Ext.Msg.alert('Drop gesture', 'Dropped patient ' + data.patientData.name +
                ' on hospital ' + h.data.name);
            return true;
        }
    });
    

    }

    Ext.require(['*']);

    Ext.onReady(function() {

    var patients = [{
        insuranceCode: '11111',
        name: 'Fred Bloggs',
        address: 'Main Street',
        telephone: '555 1234 123'
    }, {
        insuranceCode: '22222',
        name: 'Fred Bansod',
        address: 'Van Ness',
        telephone: '666 666 666'
    }, {
        insuranceCode: '33333',
        name: 'Fred Mercury',
        address: 'Over The Rainbow',
        telephone: '555 321 0987'
    }, {
        insuranceCode: '44444',
        name: 'Fred Forsyth',
        address: 'Blimp Street',
        telephone: '555 111 2222'
    }, {
        insuranceCode: '55555',
        name: 'Fred Douglass',
        address: 'Talbot County, Maryland',
        telephone: 'N/A'
    }];
    
    Ext.define('Patient', {
        extend: 'Ext.data.Model',
        idProperty: 'insuranceCode',
        fields: [{
                name: 'name'
            }, {
                name: 'address'
            }, {
                name: 'telephone'
            }]
    });
    
    var patientStore = Ext.create('Ext.data.Store', {
        model: 'Patient',
        data: patients
    });
    
    var hospitals = [{
        code: 'AAAAA',
        name: 'Saint Thomas',
        address: 'Westminster Bridge Road, SE1 7EH',
        telephone: '020 7188 7188'
    }, {
        code: 'BBBBB',
        name: 'Queen\'s Medical Centre',
        address: 'Derby Road, NG7 2UH',
        telephone: '0115 924 9924'
    }, {
        code: 'CCCCC',
        name: 'Saint Bartholomew',
        address: 'West Smithfield, EC1A 7BE',
        telephone: '020 7377 7000'
    }, {
        code: 'DDDDD',
        name: 'Royal London',
        address: 'Whitechapel, E1 1BB',
        telephone: '020 7377 7000'
    }];
    
    Ext.define('Hospital', {
        extend: 'Ext.data.Model',
        idProperty: 'code',
        fields: [{
            name: 'name'
        }, {
            name: 'address'
        }, {
            name: 'telephone'
        }]
    });
    
    var hospitalStore = Ext.create('Ext.data.Store', {
        model: 'Hospital',
        data: hospitals
    });
    
    var patientView = Ext.create('Ext.view.View', {
        cls: 'patient-view',
        tpl: '<tpl for=".">' +
                '<div class="patient-source"><table><tbody>' +
                    '<tr><td class="patient-label">Name</td><td class="patient-name">{name}</td></tr>' +
                    '<tr><td class="patient-label">Address</td><td class="patient-name">{address}</td></tr>' +
                    '<tr><td class="patient-label">Telephone</td><td class="patient-name">{telephone}</td></tr>' +
                '</tbody></table></div>' +
             '</tpl>',
        itemSelector: 'div.patient-source',
        overItemCls: 'patient-over',
        selectedItemClass: 'patient-selected',
        singleSelect: true,
        store: patientStore,
        listeners: {
            render: initializePatientDragZone
        }
    });
    
    var helpWindow = Ext.create('Ext.Window', {
        title: 'Source code',
        width: 920,
        height: 500,
        closeAction: 'hide',
        layout: 'fit',
        items: [
            {
                xtype: 'textarea',
                itemId: 'srcTextArea'
            }
        ],
        listeners: {
            render: function(w) {
                Ext.Ajax.request({
                    url: 'dragdropzones.js',
                    success: function(r) {
                        w.down('#srcTextArea').setValue(r.responseText);
                    }
                });
            }
        }
    });
    
    var hospitalGrid = Ext.create('Ext.grid.Panel', {
        title: 'Hospitals',
        region: 'center',
        margins: '0 5 5 0',
        bbar: [{
            text: 'View Source',
            handler: function() {
                helpWindow.show();
            }
        }],
        sortableColumns: false,
        columns: [{
            dataIndex: 'name',
            header: 'Name',
            width: 200
        }, {
            dataIndex: 'address',
            header: 'Address',
            width: 300
        }, {
            dataIndex: 'telephone',
            header: 'Telephone',
            width: 100
        }],
        features: [{
            ftype:'rowbody',
            setup: function(rows, rowValues) {
                Ext.grid.feature.RowBody.prototype.setup.apply(this, arguments);
                rowValues.rowBody = 'Drop Patient Here';
                rowValues.rowBodyDivCls = 'hospital-target';
            }
        }],
        viewConfig: {
            listeners: {
                render: initializeHospitalDropZone
            }
        },
        store: hospitalStore
    });
    
    Ext.create('Ext.Viewport', {
        layout: 'border',
        items: [{
            cls: 'app-header',
            region: 'north',
            height: 30,
            html: '<h1>Patient Hospital Assignment</h1>',
            margins: '5 5 5 5'
        }, {
            title: 'Patients',
            region: 'west',
            width: 300,
            margins: '0 5 5 5',
            items: patientView
        }, hospitalGrid ]
    });
    

    });

    评论

报告相同问题?

悬赏问题

  • ¥15 用三极管设计—个共射极放大电路
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示