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>
ありがとう