【问题标题】:Flex/DataGrid: update each row dataProvider is changedFlex/DataGrid:更新每一行dataProvider被改变
【发布时间】:2010-03-24 13:57:50
【问题描述】:

在 DataGrid 中,当我对 dataProvider 进行更新时,如何强制调用可见行上所有 itemRenderer 的 data()。

在按下 doSomething 后,网格未更新。如果我有一个大列表,则在向下滚动然后再次备份时完成更新,或者在 TreeGrid 的情况下我打开/关闭一个节点。

<?xml version="1.0" ?>
<mx:VBox
xmlns:mx="http://www.adobe.com/2006/mxml"
xmlns:flexlib="http://code.google.com/p/flexlib/"
initialize="_initialize()">

<mx:Script>
<![CDATA[

    import mx.events.CollectionEvent;

    import mx.controls.Alert;
    import Icons;

    [Bindable]
    private var dataProvider0:XML;

    private function _initialize():void
    {
        dataProvider0 = <node>
                <node label="A" option="1">
                    <node label="C" option="1"/>
                    <node label="D" option="1"/>
                </node>
                <node label="B" option="1">
                    <node label="E" option="1"/>
                    <node label="F" option="1"/>
                </node>
            </node>;

    }

    private function doSomething():void
    {

        dataProvider0.node[0].@option = 0;
        dataProvider0.node[0].node[0].@option = 0;


    }


]]>
</mx:Script>

<flexlib:TreeGrid
    id="treeGrid1"
    width="500"
    height="300"
    showRoot="false"
    verticalTrunks="none"
    paddingLeft="0"
    disclosureClosedIcon="{Icons.folderClosed}"
    disclosureOpenIcon="{Icons.folderOpen}"
    dataProvider="{dataProvider0}">

    <flexlib:columns>
        <flexlib:TreeGridColumn dataField="@label" headerText="Section"/>
        <mx:DataGridColumn dataField="@option" headerText="Option" width="50">
            <mx:itemRenderer>
                 <mx:Component>

                    <mx:Box xmlns:mx="http://www.adobe.com/2006/mxml" paddingBottom="0" paddingLeft="0" paddingRight="0" paddingTop="0" verticalAlign="middle" horizontalAlign="center" width="100%" height="100%">

                        <mx:Script>
                        <![CDATA[

                            [Bindable]
                            override public function set data(value:Object):void
                            {
                                super.data = value;
                                chkMain.selected = value.@option == "1";
                            }

                        ]]>
                        </mx:Script>

                        <mx:CheckBox id="chkMain"/>

                    </mx:Box>

                </mx:Component>
            </mx:itemRenderer>
        </mx:DataGridColumn>
    </flexlib:columns>

</flexlib:TreeGrid>

<mx:DataGrid
    id="dataGrid1"
    width="500"
    height="300"
    dataProvider="{dataProvider0.node}">

    <mx:columns>
        <mx:DataGridColumn dataField="@label" headerText="Section"/>
        <mx:DataGridColumn dataField="@option" headerText="Option" width="50">
            <mx:itemRenderer>
                 <mx:Component>

                    <mx:Box xmlns:mx="http://www.adobe.com/2006/mxml" paddingBottom="0" paddingLeft="0" paddingRight="0" paddingTop="0" verticalAlign="middle" horizontalAlign="center" width="100%" height="100%">

                        <mx:Script>
                        <![CDATA[

                            [Bindable]
                            override public function set data(value:Object):void
                            {
                                super.data = value;
                                chkMain.selected = value.@option == "1";
                            }

                        ]]>
                        </mx:Script>

                        <mx:CheckBox id="chkMain"/>

                    </mx:Box>

                </mx:Component>
            </mx:itemRenderer>
        </mx:DataGridColumn>
    </mx:columns>

</mx:DataGrid>

<mx:Button label="Do" click="doSomething()"/>

</mx:VBox>

【问题讨论】:

    标签: apache-flex actionscript flex-datagrid


    【解决方案1】:

    你试过了吗

    private function doSomething():void
    {
    
        dataProvider0.node[0].@option = 0;
        dataProvider0.node[0].node[0].@option = 0;
    
        // force a redraw at earliest opportunity
        treeGrid1.invalidateDisplayList(); 
    
    }
    

    【讨论】:

      【解决方案2】:

      试试这个:

      private function doSomething():void
      {
          dataProvider0.node[0].@option = 0;
          dataProvider0.node[0].node[0].@option = 0;
      
          treeGrid1.dataProvider.refresh();
          dataGrid1.dataProvider.refresh();
      }
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2011-04-19
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2012-12-04
        • 1970-01-01
        • 2015-05-08
        • 1970-01-01
        相关资源
        最近更新 更多