0

ItemRendererとItemEditorを備えたデータグリッドがあります。クリックすると、データグリッドが編集可能になるため、編集セルの値を変更できます。しかし、たとえば、タブキーを使用してこれらの変更を有効にすると、itemrenderの値は最初と同じになり、変更は表示されません。

それを解決する方法を教えていただけますか?

<mx:DataGridColumn dataField="scRub2" headerText="{sNomCol2}" 
editable="true" width="{iNomCol2}"id="dgc1" wordWrap="true"
                                                                itemRenderer="itemRenderer.MultilineHTMLRenderer"
itemEditor="itemRenderer.irHtmlText"
editorDataField="htmlModif"

// itemEditor

<?xml version="1.0" encoding="utf-8"?>

<fx:Script>
    <![CDATA[

        public var htmlModif:String;
        protected function lblData_changeHandler(event:Event):void
        {
            htmlModif = lblData.htmlText;
        }
    ]]>
</fx:Script>


<mx:TextArea id="lblData" top="0" left="0" right="0" bottom="0"     
             htmlText="{dataGridListData.label}"  preinitialize="initTA()"
             change="lblData_changeHandler(event)">
    <fx:Script>
        <![CDATA[

            import flash.events.Event;

            import mx.controls.dataGridClasses.DataGridListData;

            import mx.controls.dataGridClasses.DataGridListData;
            import mx.controls.listClasses.BaseListData;
            [Bindable("dataChange")] private var _listData : BaseListData;

            override public function get listData():BaseListData
            {
                return _listData;            
            }                   
            override public function set listData( value : BaseListData ) : void
            {
                _listData = value;
            }

            private function onChange(event:Event):void
            {
                this.data[ (listData as DataGridListData).dataField ] = lblData.htmlText;
            }
            public function initTA():void {         
                addEventListener("dataChange", handleDataChanged);
            }   

            public function handleDataChanged(event:Event):void {       
                // Cast listData to DataGridListData. 
                var myListData:DataGridListData = 
                    DataGridListData(listData);
                // Access information about the data passed 
                // to the cell renderer.
                trace("row index: " + String(myListData.rowIndex) + 
                    " column index: " + String(myListData.columnIndex));

            }
        ]]>
    </fx:Script>
</mx:TextArea>

ありがとう

4

1 に答える 1

0

コードを実行しませんでしたが、フィールドhtmlModifget関数に変更すると問題が解決すると思います

public var htmlModif:String;
        protected function lblData_changeHandler(event:Event):void
        {
            htmlModif = lblData.htmlText;
        }

    public function get htmlModif():String
    {
        return lblData.htmlText;
    }

役立つことを願っています

于 2012-05-29T17:22:30.177 に答える