您的位置:首页 > Web前端 > JavaScript

无废话ExtJs 入门教程十五[员工信息表Demo:AddUser]

2012-06-25 20:25 489 查看
extjs技术交流,欢迎加群(521711109)


前面我们共介绍过10种表单组件,这些组件是我们在开发过程中最经常用到的,所以一定要用到非常熟练才可以,今天我们会通过一个员工信息表实例,再把这些组件串一下。

(1)TextField (2)Botton (3)NumberField (4)Hidden (5)DataFiedl (6)RadioGroup (7)CheckBoxGroup (8)Combobox (9)File (10)Editor

1.代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<!--ExtJs框架开始-->
<script type="text/javascript" src="/Ext/adapter/ext/ext-base.js"></script>
<script type="text/javascript" src="/Ext/ext-all.js"></script>
<script src="/Ext/src/locale/ext-lang-zh_CN.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="/Ext/resources/css/ext-all.css" />
<style type="text/css">
.x-form-unit
{
height: 22px;
line-height: 22px;
padding-left: 2px;
display: inline-block;
display: inline;
}
</style>
<!--ExtJs框架结束-->
<script type="text/javascript">

//----------------------重写文本框开始----------------------//
Ext.override(Ext.form.TextField, {
unitText: '',
onRender: function (ct, position) {
Ext.form.TextField.superclass.onRender.call(this, ct, position);
// 如果单位字符串已定义 则在后方增加单位对象
if (this.unitText != '') {
this.unitEl = ct.createChild({
tag: 'div',
html: this.unitText
});
this.unitEl.addClass('x-form-unit');
// 增加单位名称的同时 按单位名称大小减少文本框的长度 初步考虑了中英文混排 未考虑为负的情况
this.width = this.width - (this.unitText.replace(/[^\x00-\xff]/g, "xx").length * 6 + 2);
// 同时修改错误提示图标的位置
this.alignErrorIcon = function () {
this.errorIcon.alignTo(this.unitEl, 'tl-tr', [2, 0]);
};
}
}
});
//----------------------重写文本框结束----------------------//

Ext.onReady(function () {
//初始化标签中的Ext:Qtip属性。
Ext.QuickTips.init();
Ext.form.Field.prototype.msgTarget = 'side';

//------------第一列内容开始-------------//
//姓名
var txtusername = new Ext.form.TextField({
width: 130,
allowBlank: false,
maxLength: 4,
name: 'username',
fieldLabel: '姓名',
blankText: '请输入姓名',
maxLengthText: '姓名不能超过4个字符'
});
//政治面貌数据源
var combostore = new Ext.data.ArrayStore({
fields: ['id', 'name'],
data: [[1, '团员'], [2, '党员'], [3, '其他']]
});
//政治面貌下拉列表
var cobpolitical = new Ext.form.ComboBox({
width: 130,
allowBlank: false,
fieldLabel: '政治面貌',
store: combostore,
displayField: 'name',
valueField: 'id',
triggerAction: 'all',
emptyText: '请选择...',
blankText: '请选择政治面貌',
editable: false,
mode: 'local'
});
//毕业院校
var txtgraduateschool = new Ext.form.TextField({
width: 130,
allowBlank: false,
maxLength: 10,
name: 'graduateschool',
fieldLabel: '毕业院校',
blankText: '请输入毕业院校',
maxLengthText: '毕业院校不能超过10个字符'
});
//通信地址
var txtaddress = new Ext.form.TextField({
width: 130,
allowBlank: false,
maxLength: 30,
name: 'address',
fieldLabel: '通信地址',
blankText: '请输入通信地址',
maxLengthText: '通信地址不能超过30个字符'
});
//第一列包含4行
var column1 = {
columnWidth: .28,
layout: 'form',
items: [
txtusername, cobpolitical, txtgraduateschool, txtaddress
]
};
//------------第一列内容结束-------------//
//------------第二列内容开始-------------//
//性别
var rdosex = new Ext.form.RadioGroup({
fieldLabel: '性别',
width: 130,
style: 'padding-top:3px;height:17px;',
items: [{ name: 'sex', inputValue: '0', boxLabel: '男', checked: true }, { name: 'sex', inputValue: '1', boxLabel: '女'}]
});
//身高
var numheight = new Ext.form.NumberField({
fieldLabel: '身高',
width: 117,
decimalPrecision: 0,
minValue: 1,
maxValue: 400,
name: 'height',
unitText: ' cm',
allowBlank: false,
blankText: '请输入身高'
});
//毕业专业
var txtprofessional = new Ext.form.TextField({
width: 130,
allowBlank: false,
maxLength: 30,
name: 'professional',
fieldLabel: '毕业专业',
blankText: '请输入毕业专业',
maxLengthText: '毕业专业不能超过30个字符'
});
//联系电话
var txtphone = new Ext.form.TextField({
width: 130,
allowBlank: false,
maxLength: 20,
name: 'phone',
fieldLabel: '联系电话',
blankText: '请输入联系电话',
maxLengthText: '联系电话不能超过20个字符'
});
//第二列包含4行
var column2 = {
columnWidth: .28,
layout: 'form',
items: [rdosex, numheight, txtprofessional, txtphone]
};
//------------第二列内容结束-------------//
//------------第三列内容开始-------------//
//年龄
var numage = new Ext.form.NumberField({
fieldLabel: '年龄',
width: 117,
decimalPrecision: 0,
minValue: 1,
maxValue: 60,
name: 'age',
unitText: ' 岁',
allowBlank: false,
blankText: '请输入年龄'
});
//体重
var numweight = new Ext.form.NumberField({
fieldLabel: '体重',
width: 117,
decimalPrecision: 0,
minValue: 1,
maxValue: 300,
name: 'age',
unitText: ' kg',
allowBlank: false,
blankText: '请输入体重'
});
//毕业日期
var dategraduation = new Ext.form.DateField({
fieldLabel: '毕业日期',
name: 'graduationdate',
width: 117,
format: 'Y-m-d',
editable: false,
allowBlank: false,
blankText: '请选择毕业日期'
});
//第三列包含3行
var column3 = {
columnWidth: .25,
layout: 'form',
items: [numage, numweight, dategraduation]
};
//------------第三列内容结束-------------//
//------------第四列内容开始-------------//
//创建div组件
var imagebox = new Ext.BoxComponent({
autoEl: {
style: 'width:65px;height:60px;margin:0px auto;border:1px solid #ccc; text-align:center;padding-top:10px;margin-bottom:8px',
tag: 'div',
id: 'imageshow',
html: '暂无相片'
}
});
var uploadbutton = new Ext.Button({
text: '上传相片',
style: 'margin:0px auto;',
handler: function () {
alert('弹出新窗体上传相片!');
}
});
var column4 = {
columnWidth: .16,
layout: 'form',
items: [imagebox, uploadbutton]
};
//------------第四列内容结束-------------//
//招聘来源
var checksource = new Ext.form.CheckboxGroup({
fieldLabel: '招聘来源',
style: 'padding-top:3px;height:17px;',
items: [{
boxLabel: '报纸招聘',
inputValue: '0'
}, {
boxLabel: '校园招聘',
inputValue: '1'
}, {
boxLabel: '人才市场',
inputValue: '2'
}, {
boxLabel: '招聘网站',
inputValue: '3'
}]
});
//创建文本上传域
var exteditor = new Ext.form.HtmlEditor({
fieldLabel: '其他信息',
width: 745,
height: 320
});
//表单
var form = new Ext.form.FormPanel({
frame: true,
title: '员工信息表',
style: 'margin:10px',
labelWidth: 70,
buttonAlign: 'center',
items: [{
layout: 'column',
items: [
column1,
column2,
column3,
column4
]
}, checksource,
exteditor
],
buttons: [{
text: '保存',
handler: function () { alert('保存方法!') }
}, {
text: '重置',
handler: function () { alert('重置方法!') }
}]
});
//窗体
var win = new Ext.Window({
title: '窗口',
width: 900,
height: 580,
resizable: true,
modal: true,
closable: true,
maximizable: true,
minimizable: true,
buttonAlign: 'center',
items: form
});
win.show();

});
</script>
</head>
<body>
<!--
说明:
(1)254行layout: 'column':以列的方式布局,这里总共分了4列,布局的内容下个教程讲解。
-->
</body>
</html>


2.效果如下:



转载请注明出处:http://www.cnblogs.com/iamlilinfeng
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: