0

我有以下函数将项目添加到数据库然后返回到数据网格。数据管理方法是PHP。我的问题是数据库已经收到新数据,但数据网格没有新记录。

这是代码的简化版本

    <fx:Script>
        <![CDATA[
            import mx.controls.Alert;
            import mx.events.CloseEvent;
            import mx.events.FlexEvent;
            import mx.rpc.events.ResultEvent;

            import spark.events.GridItemEditorEvent;

            protected function dataGrid_creationCompleteHandler(event:FlexEvent):void
            {
                getAllUserResult.token = userService.getAllUser();

            }


            protected function button_clickHandler(event:MouseEvent):void
            {

                var user:User = new User();

                user.idUser = parseInt(idUserTextInput.text);
                user.userName = userNameTextInput.text;
                user.password = passwordTextInput.text;

                createUserResult.token = userService.createUser(user);

                userService.commit();


                //getAllUserResult.token = userService.getAllUser();
                //dataGrid.invalidateDisplayList();

                //var e:FlexEvent;
                //dataGrid_creationCompleteHandler(e);

                //user.idUser=createUserResult.token.result as int;
                //dataGrid.dataProvider.addItem(user);

                this.currentState="State1";
            }
    </fx:Script>


<s:states>
    <s:State name="State1"/>
    <s:State name="Add"/>
</s:states>


    <fx:Declarations>
        <s:CallResponder id="getAllUserResult"/>
        <userservice:UserService id="userService"
                                   fault="Alert.show(event.fault.faultString + '\n' + event.fault.faultDetail)"
                                   showBusyCursor="true"/>
        <valueObjects:User id="user"/>
        <s:CallResponder id="createUserResult"/>

    </fx:Declarations>



<s:DataGrid id="dataGrid" includeIn="State1" x="95" y="10" width="961" height="505"
                creationComplete="dataGrid_creationCompleteHandler(event)" editable="true"
                gridItemEditorSessionSave="dataGrid_gridItemEditorSessionSaveHandler(event)"
                requestedRowCount="4" >
        <s:columns>
            <s:ArrayList>
                <s:GridColumn dataField="idUser" headerText="idUser"></s:GridColumn>
                <s:GridColumn dataField="userName" headerText="userName"></s:GridColumn>
                <s:GridColumn dataField="password" headerText="password"></s:GridColumn>

            </s:ArrayList>
        </s:columns>
        <s:typicalItem>
            <fx:Object idUser="idUser1" Name="Name1" password="password1"></fx:Object>
        </s:typicalItem>
        <s:AsyncListView list="{getAllUserResult.lastResult}"/>
    </s:DataGrid>

    <s:Button id="button" includeIn="Add" x="695" y="407" label="CreateUser"
              click="button_clickHandler(event)"/>


    <s:Form includeIn="Add" x="74" y="21" width="343" height="362">
            <s:FormItem width="200" label="IdUser">
                <s:helpContent >
                    <s:VGroup>
                        <s:Label width="76" height="42" text="Auto Generate"></s:Label>
                    </s:VGroup>
                </s:helpContent>
                <s:Label id="idUserTextInput" text="{user.idUser}"/>
            </s:FormItem>
            <s:FormItem label="UserName" required="true">
                <s:TextInput id="userNameTextInput" text="{user.userName}"/>
            </s:FormItem>
            <s:FormItem label="Password" required="true">
                <s:TextInput id="passwordTextInput" text="{user.password}"/>
            </s:FormItem>

    </s:Form>

我已经尝试过 serval 方法来调试(button_clickHandler 中的注释函数),但是结果仍然相同。

还有什么方法可以试试??

4

1 回答 1

0

您是否尝试过刷新数据提供者?

于 2012-11-16T11:51:17.390 回答