flex_可编辑表格示例;

=>TheEditableGridItemEditor(自定义组件)

<?xml version="1.0" encoding="utf-8"?>
<mx:HBox xmlns:fx="http://ns.adobe.com/mxml/2009"
         xmlns:s="library://ns.adobe.com/flex/spark"
         xmlns:mx="library://ns.adobe.com/flex/mx" creationComplete="init()">
    
    <fx:Script>
        <![CDATA[
            import mx.collections.ArrayCollection;
            import mx.events.ListEvent;
            
            [Bindable]
            private var arrayForCombo:ArrayCollection = new ArrayCollection([
                {type: "军阀"},
                {type: "雇佣兵"}
            ]);
            
            [Bindable]
            public var personType:String;    // 应该用于存储修改了的值。
            
            private function init():void
            {
                personType = data.type;    // data为datagrid行信息;
                
                for(var i:int=0, len:int=arrayForCombo.length; i<len; i++) {
                    if(arrayForCombo[i].type == data.type) {
                        combo.selectedIndex = i;    // 让combobox显示对应的数据。
                    }
                }
            }
            
            protected function combo_changeHandler(event:ListEvent):void
            {
                personType = combo.selectedItem.type;
            }
            
        ]]>
    </fx:Script>
    
    <fx:Declarations>
        <!-- 将非可视元素(例如服务、值对象)放在此处 -->
    </fx:Declarations>
    
    <!--view-->
    <mx:ComboBox id="combo" dataProvider="{arrayForCombo}" labelField="type" change="combo_changeHandler(event)"/>
</mx:HBox>

=>TheEditableGrid(应用程序)

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
               xmlns:s="library://ns.adobe.com/flex/spark"
               xmlns:mx="library://ns.adobe.com/flex/mx"
               minWidth="955" minHeight="600" pageTitle="可编辑表格示例">
    <fx:Script>
        <![CDATA[
            import mx.collections.ArrayCollection;
            
            [Bindable]
            private var arrayForGrid:ArrayCollection = new ArrayCollection([
                {name: "唐龙", age: 23, email: "23@lf.com", type: "军阀"},
                {name: "楚源", age: 11, email: "11@lf.com", type: "雇佣兵"},
                {name: "猴子", age: 12, email: "12!lf.com", type: "雇佣兵"}
            ]);
        ]]>
    </fx:Script>
    
    <fx:Declarations>
        <!-- 将非可视元素(例如服务、值对象)放在此处 -->
    </fx:Declarations>
    
    <!--view-->
    <mx:DataGrid id="dgrid" dataProvider="{arrayForGrid}" editable="true" width="350" height="120"
                 verticalCenter="0" horizontalCenter="0">
        <mx:columns>
            <mx:DataGridColumn headerText="姓名" dataField="name"/>
            <mx:DataGridColumn headerText="年龄" dataField="age"/>
            <mx:DataGridColumn headerText="邮箱地址" dataField="email" editable="false"/>
            <mx:DataGridColumn headerText="身份" dataField="type" editorDataField="personType"
                               itemEditor="TheEditableGridItemEditor"/>
        </mx:columns>
    </mx:DataGrid>
    
</s:Application>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值