データベースからの文字列を表示するデータグリッド(6列)があります。labelfunctionを使用して、文字列内のhtml特殊文字(&apos、&ampなど)をエスケープしようとしています。
私はこれをネットで見つけました:
protected function makeSpecialChars(item:Object,dgName:DataGridColumn):String {
var s:String = agentName.dataField;
var v:String = item.s;
return new XMLDocument(v).firstChild.nodeValue;
}
ただし、これを行うと、次のエラーが発生します。nullオブジェクト参照のプロパティまたはメソッドにアクセスできません。
上記のコードを次のように変更すると、これは正常に機能します。
protected function makeSpecialChars(item:Object,agentName:DataGridColumn):String {
return new XMLDocument(item.computer_name).firstChild.nodeValue;
}
ここで、computer_nameは、このデータグリッド列のデータフィールドです。
データグリッドコードの投稿:
<components:DoubleClickDataGrid xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
xmlns:components="components.*"
width="100%" height="100%"
editable="true"
focusColor="#CEDA9B"
rollOverColor="#CEDA9B"
selectionColor="#84A207"
dataProvider="{invList}"
creationComplete="doubleclickdatagrid1_creationCompleteHandler(event)"
itemEditEnd="handleInventoryEdit(event)">
<components:columns>
<mx:DataGridColumn width="120" dataField="computer_name" headerText="Computer Name" textAlign="center" labelFunction="makeSpecialChars"/>
<mx:DataGridColumn dataField="path" headerText="Path" textAlign="center" labelFunction="makeSpecialChars"/>
<mx:DataGridColumn width="110" dataField="computer_type" textAlign="center" headerText="Computer Type" />
<mx:DataGridColumn width="180" dataField="username" headerText="Username" textAlign="center" />
<mx:DataGridColumn width="90" dataField="ip_address" headerText="IP Address" textAlign="center" />
<mx:DataGridColumn width="130" dataField="mac_address" headerText="MAC Address" textAlign="center" />
<mx:DataGridColumn width="180" dataField="computer_model" headerText="Computer Model" textAlign="center" />
<mx:DataGridColumn width="70" editable="false" headerText="Actions" textAlign="center" itemRenderer="renderers.ActionRenderer" />
</components:columns>
これは今のところうまく機能しています(2列にのみlabelfunctionを適用しました)。しかし、すべての列にlabel関数を適用したいと思います...