Apache flex Flex/DataGrid:更新更改的每行数据提供程序

Apache flex Flex/DataGrid:更新更改的每行数据提供程序,apache-flex,actionscript,flex-datagrid,Apache Flex,Actionscript,Flex Datagrid,在DataGrid中,当我对dataProvider进行更新时,如何强制调用可见行上所有ItemRenders的data() 在以下情况下,按下doSomething后网格不会更新。如果我有一个较大的列表,则在向下滚动然后再次备份时完成更新,或者在TreeGrid的情况下,我打开/关闭一个节点 <?xml version="1.0" ?> <mx:VBox xmlns:mx="http://www.adobe.com/2006/mxml" xmlns:flexlib="http

在DataGrid中,当我对dataProvider进行更新时,如何强制调用可见行上所有ItemRenders的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>

;
}
私有函数doSomething():void
{
dataProvider0.node[0]。@option=0;
dataProvider0.node[0]。node[0]。@option=0;
}
]]>
您试过了吗

private function doSomething():void
{

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

    // force a redraw at earliest opportunity
    treeGrid1.invalidateDisplayList(); 

}
试试这个:

private function doSomething():void
{
    dataProvider0.node[0].@option = 0;
    dataProvider0.node[0].node[0].@option = 0;

    treeGrid1.dataProvider.refresh();
    dataGrid1.dataProvider.refresh();
}