Flex动态生成可编辑的DataGrid具体实现代码
程序员文章站
2022-03-07 18:38:31
一:先说说我写这个datagrid具有的功能 1、表头是动态生成的。 2、每行都是有序号的。 3、每行都是可以编辑、插入、删除、修改的。 4、每个单元格都是加验证的。 5、...
一:先说说我写这个datagrid具有的功能
1、表头是动态生成的。
2、每行都是有序号的。
3、每行都是可以编辑、插入、删除、修改的。
4、每个单元格都是加验证的。
5、单元格有些是经过渲染生成的比如:combobox,datefield...
二、说一些实现这些功能的困难
写这个的时候感觉都是困难不知道,走过来了也就木有神马啦,最让我费劲的就是渲染例如:combobox在渲染的时候不能用itemrenderer因为他不能绑定值,只能用itemeditor但是怎样获得这个一个经过渲染的对象,通过百度不断地百度,终于发现了classfactory这个工厂可以生产各种想要的组件。各种困难现在都记不起来了,三天时间终于完成啦。为什吗要这样写呢?因为要做数据更新系统,每年数据都会有变化,这样页面也需要变化,总不能每年都去改源码吧,不如想个法子全给他整成动态的。这就是写这个的初衷。
三、关键源码
package datagridview
{
import com.adobe.serialization.json.json;
import com.jzh.test.comboxcolumn;
import com.jzh.test.comboxitem;
import mx.collections.arraycollection;
import mx.controls.alert;
import mx.controls.combobase;
import mx.controls.combobox;
import mx.controls.datefield;
import mx.controls.radiobuttongroup;
import mx.controls.advanceddatagridclasses.advanceddatagridcolumn;
import mx.core.classfactory;
import mx.validators.regexpvalidator;
import spark.components.dropdownlist;
public class rendererutil
{
public function rendererutil()
{
}
public static function getbuttonrenderer():classfactory{
var f:classfactory=new classfactory(operatebuttons);
f.properties={};
return f;
}
public static function getnumrenderer():classfactory{
var f:classfactory=new classfactory(numlabel);
f.properties={};
return f;
}
public static function getcomboxrenderer(arr:arraycollection,label:string):classfactory{
//应该在这里查询数据库
var f:classfactory=new classfactory(combobox);
f.properties={dataprovider: arr,labelfield:label,selectedindex:'0',selecteditem:'石质路面'};//添加属性,绑定选择状态
return f;
}
public static function getradiorenderer(label:string):classfactory{
var f:classfactory=new classfactory(combobox);
var arr:arraycollection=new arraycollection();
arr.additem("是");
arr.additem("否");
f.properties={dataprovider: arr,labelfield:label,selectedindex:'0',selecteditem:'否'};//添加属性,绑定选择状态
return f;
}
public static function getdaterenderer():classfactory{
var f:classfactory=new classfactory(datefield);
f.properties={formatstring:"yyyy-mm-dd",showtoday:true};//添加属性,绑定选择状态
return f;
}
/*本来想在这渲染生成验证器的,无奈技术在达不到*/
public static function getvalidaterenderer():classfactory{
var f:classfactory=new classfactory(regexpvalidator);
f.properties={ source:"roadcode",
property:"text" ,
expression:"^[0-9]*$",
nomatcherror:"填写验证不通过时显示他提示信息" };//添加属性,绑定选择状态
return f;
}
/*测试用*/
public static function getrenderer(label:string,callback:function=null):classfactory{
var f:classfactory=new classfactory(numlabel);
f.properties={lab:label,callback:callback};
return f;
}
}
}
以上代码是渲染器部分。
1、表头是动态生成的。
2、每行都是有序号的。
3、每行都是可以编辑、插入、删除、修改的。
4、每个单元格都是加验证的。
5、单元格有些是经过渲染生成的比如:combobox,datefield...
二、说一些实现这些功能的困难
写这个的时候感觉都是困难不知道,走过来了也就木有神马啦,最让我费劲的就是渲染例如:combobox在渲染的时候不能用itemrenderer因为他不能绑定值,只能用itemeditor但是怎样获得这个一个经过渲染的对象,通过百度不断地百度,终于发现了classfactory这个工厂可以生产各种想要的组件。各种困难现在都记不起来了,三天时间终于完成啦。为什吗要这样写呢?因为要做数据更新系统,每年数据都会有变化,这样页面也需要变化,总不能每年都去改源码吧,不如想个法子全给他整成动态的。这就是写这个的初衷。
三、关键源码
复制代码 代码如下:
package datagridview
{
import com.adobe.serialization.json.json;
import com.jzh.test.comboxcolumn;
import com.jzh.test.comboxitem;
import mx.collections.arraycollection;
import mx.controls.alert;
import mx.controls.combobase;
import mx.controls.combobox;
import mx.controls.datefield;
import mx.controls.radiobuttongroup;
import mx.controls.advanceddatagridclasses.advanceddatagridcolumn;
import mx.core.classfactory;
import mx.validators.regexpvalidator;
import spark.components.dropdownlist;
public class rendererutil
{
public function rendererutil()
{
}
public static function getbuttonrenderer():classfactory{
var f:classfactory=new classfactory(operatebuttons);
f.properties={};
return f;
}
public static function getnumrenderer():classfactory{
var f:classfactory=new classfactory(numlabel);
f.properties={};
return f;
}
public static function getcomboxrenderer(arr:arraycollection,label:string):classfactory{
//应该在这里查询数据库
var f:classfactory=new classfactory(combobox);
f.properties={dataprovider: arr,labelfield:label,selectedindex:'0',selecteditem:'石质路面'};//添加属性,绑定选择状态
return f;
}
public static function getradiorenderer(label:string):classfactory{
var f:classfactory=new classfactory(combobox);
var arr:arraycollection=new arraycollection();
arr.additem("是");
arr.additem("否");
f.properties={dataprovider: arr,labelfield:label,selectedindex:'0',selecteditem:'否'};//添加属性,绑定选择状态
return f;
}
public static function getdaterenderer():classfactory{
var f:classfactory=new classfactory(datefield);
f.properties={formatstring:"yyyy-mm-dd",showtoday:true};//添加属性,绑定选择状态
return f;
}
/*本来想在这渲染生成验证器的,无奈技术在达不到*/
public static function getvalidaterenderer():classfactory{
var f:classfactory=new classfactory(regexpvalidator);
f.properties={ source:"roadcode",
property:"text" ,
expression:"^[0-9]*$",
nomatcherror:"填写验证不通过时显示他提示信息" };//添加属性,绑定选择状态
return f;
}
/*测试用*/
public static function getrenderer(label:string,callback:function=null):classfactory{
var f:classfactory=new classfactory(numlabel);
f.properties={lab:label,callback:callback};
return f;
}
}
}
以上代码是渲染器部分。
下一篇: 关于javasript中参数传递的深研究