flex datagrid column itemRenderer


工厂

package com.gwtjs.renderer.grid
{
	import mx.core.IFactory;
	
	//必须要实现IFactory接口
	public class EnableItemIFactory implements IFactory{
		public function EnableItemIFactory(){
			super();
		}
		
		public function newInstance():*{
			//实例化渲染器,实现具体功能
			return new EnableItemRenderer();
		}
	}
}



视图

<?xml version="1.0" encoding="utf-8"?>
<mx:HBox xmlns:mx="http://www.adobe.com/2006/mxml" backgroundAlpha="0.0" width="100%" horizontalAlign="center">
	<!--
	使用参考:
	[Bindable] //定义渲染器 - 是否
	private var enabledRender:IFactory = new EnableItemIFactory();
	<mx:DataGridColumn dataField="enabled" headerText="是否启用" width="86" itemRenderer="{enabledRender}" />
	-->
	<mx:Style>
		.upText{color:#00661A; textAlign:right;}
		.downText{color:#FF0000; textAlign:right;}
	</mx:Style>
	<mx:Script>
		<![CDATA[
			[Embed(source='assets.png')]
			private static const tick:Class;
			[Embed(source='assets.png')]
			private static const cross:Class;
			
			[Bindable]
			private var class_name:String;
			private function getImage(data:Object):Object {if('1'==data.enabled||true==data.enabled||'true'==data.enabled||1==Number(data.enabled)){
				class_name='upText';
				return tick;
			}else{
				class_name='downText';
				return cross;
			}
			}
			
			public function getState(value:String):String{
				if('1'==value){
					return "是";//"../assets/images/icon/user_female.png";}
					return "否";//"../assets/images/icon/user_suit.png";
				}]]>
	</mx:Script>
	<mx:Image id="stateImage" source="{getImage(this.data)}"/>
</mx:HBox>



引用:


[Bindable] //定义渲染器 - 是否
	private var enabledRender:IFactory = new EnableItemIFactory();
	<mx:DataGridColumn dataField="enabled" headerText="是否启用" width="86" itemRenderer="{enabledRender}" />










  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值