前几天学习了ExtJS的各种布局后,以下就是各种实践,从简单做起。


  实现目的:

    一个提交表单页,一个显示信息页,表单为个人基本资料输入,显示页为基本信息展示。

  内容:

    总体布局为border布局,展示页为west,提交表单为center。展示页可折叠,默认为折叠状态。


    1、展示页用一个panel展示。可折叠,默认为折叠状态。点击提交后展示,点击关闭后关闭。 

     var show = Ext.create('Ext.panel.Panel',{
region: 'west',
title: 'Show',
width: 150,
margin: '5 2 5 5',
collapsible: true,
collapsed: true,
});

    collapsed默认为折叠状态。


   2、表单页。内容有:姓名输入、性别选择、出生日期、职务、备注。分别用到5种组件。

    (1) 姓名输入:组件选择Textfield。  

     var form_name = Ext.create('Ext.form.TextField',{
id: 'form_name',
name: 'name',
fieldLabel: 'Name',
labelWidth: 60
});

    (2) 性别选择:组件选择RadioGroup.  

     var form_sex = Ext.create('Ext.form.RadioGroup',{
name: 'sex',
fieldLabel: 'Sex',
columns: 2,
vertical: true,
labelWidth: 60,
items: [
{boxLabel: 'Man', id: 'man', name: 'sex', inputValue: '1'},
{boxLabel: 'Woman', id: 'woman', name: 'sex', inputValue: '2'}
]
});

    (3) 出生日期:组件选择Date.

     var form_dateTime = Ext.create('Ext.form.Date',{
id: 'form_date',
name: 'dateTime',
fieldLabel: 'DateTime',
labelWidth: 60,
editable: false,
maxValue: new Date()
});

    (4) 职务:组件选择ComboBox.

     var form_work = Ext.create('Ext.form.ComboBox',{
id: 'form_work',
name: 'work',
fieldLabel: 'Work',
labelWidth: 60,
editable: false,
store: new Ext.data.Store({
fields: ['position','value'],
data: [
{'position': 'Engineer', 'value': '1'},
{'position': 'Boss', 'value': '2'},
{'position': 'director', 'value': '3'}
]
}),
queryMode: 'local',
displayField: 'position',
valueField: 'value'
});

    (5) 备注:组件选择TextArea.

     var form_remark = Ext.create('Ext.form.TextArea',{
id: 'form_remark',
name: 'remark',
fieldLabel: 'Remark',
labelWidth: 60,
flex: 1
});


    Form其子组件布局选择为vbox,vbox配置控件宽度与父组件宽度一样。

    下面加2个按钮,按钮位置可以设置buttonAlign来定位,这里默认设置靠右。

    关于控件值的获取,通过各自id来获取控件,然后通过getValue()获取值,其中RadioGroup控件通过各自id获取控件,获取的值为true和false,采用三目运算符进行转换输出。最后comboBox组件获取值为getRawValue().

    除了最后备注控件,其他控件高度为默认高度,将textArea加个属性flex: 1,表示剩余高度由textArea填满。

    信息的展示使用update( String/Object htmlOrData, [Boolean loadScripts], [Function callback] )方法更新。

     var form = Ext.create('Ext.form.Panel',{
title: 'Form',
region: 'center',
border: true,
id: 'formId',
margin: '5 2 5 5',
layout: {
type: 'vbox',
align: 'stretch'
},
items: [form_name,form_sex,form_dateTime,form_work,form_remark],
buttons: [{
text: 'Save',
handler: function(){
var name = Ext.getCmp('form_name').getValue();
var sex = Ext.getCmp('man').getValue() ? 'man' : 'woman';
var dateTime = Ext.getCmp('form_date').getValue();
var work = Ext.getCmp('form_work').getRawValue();
var remark = Ext.getCmp('form_remark').getValue(); show.update('<p1>name: </p1>' + name + '<br />' + 'Sex: ' + sex + '<br />' + 'DateTime: ' + Ext.Date.format(dateTime, 'Y-m-d') + '<br />' + 'Work: ' + work + '<br />' + 'remark: ' + remark);
}
},{
text: 'Cancel',
handler: function(){
show.update();
}
}]
});

    最后将两个结合起来:

    var message = Ext.create('Ext.panel.Panel',{
title: 'Message Layout',
titleAlign: 'center',
layout: 'border',
width: 500,
height: 400,
border: true,
renderTo: Ext.getBody(),
items: [show,form]
});

    效果:

【ExtJS】简单布局应用的更多相关文章

  1. ExtJs常用布局--layout详解(含实例)

    序言: 笔者用的ExtJs版本:ext-3.2.0 ExtJs常见的布局方式有:border.form.absolute.column.accordion.table.fit.card.anchor ...

  2. WPF简单布局 浅尝辄止

            WPF的窗口只能包含一个元素,为了在WPF窗口中放置多个元素并创建更实用的用户界面,需要在窗口上放置一个容器,然后在容器中放置其它元素. 注意:造成这一限制的原因是window类继承自 ...

  3. table 和 div 简单布局

    table 简单布局 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:// ...

  4. 【JQuery Easy UI】后台管理系统的简单布局分享

    重要说明:本博已迁移到 石佳劼的博客.有疑问请到 文章新地址 留言..! 近期做的一个简单的后台管理系统,当中用到了JQuery Easy UI框架,对于撸主这样的把控件能摆整齐就谢天谢地的码农来说, ...

  5. Masonry 布局 cell 高度适应的一种方案(实现类似朋友圈简单布局)

    来源:伯乐在线 - 夏天然后 链接:http://ios.jobbole.com/89298/ 点击 → 申请加入伯乐在线专栏作者 前言: 我模仿的是微博的布局所以也就没有 评论动态刷新cell. 1 ...

  6. extjs 简单入门

    中文网站:http://extjs.org.cn/ 英文网站:http://www.sencha.com/products/extjs/ 1.简介 extJS是一种主要用于创建前端用户界面,是一个基本 ...

  7. 利用CSS简单布局的不同组合类型

    关于CSS布局页面的简单组合方式: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " ...

  8. CSS学习之首页简单布局

    作为一个PHPer,在前端方面javascript.jquery这些的日常工作还搞的定.可对于div+css这些东西可就头疼了,所以现在开始学习CSS 跟着燕十八的教程开始从最基础学起,首先练习一个简 ...

  9. Extjs Column布局常见问题及解决方法

    原文地址:http://blog.csdn.net/weoln/article/details/4339533 第一次用Extjs的column布局时遇见了很多问题,记录下来,供大家参考.column ...

随机推荐

  1. BZOJ 2038 小z的袜子(莫队)

    Description 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……具体来说,小Z把这N只袜 ...

  2. Mathcad操作tips:2D绘图

    1. 直接输入算式进行绘图(QuickPlot) 2. 先定义函数,再利用函数绘制多个曲线.一张图最多支持16条曲线.留意“,”的用法. 3. 利用空格键和","在现有绘图上增加新 ...

  3. Redis 工具类

    项目里的Redis 工具类,写下来以备后用 public class RedisConnector { public class RedisParseResult<T> { public ...

  4. EntityFramework Code First 模式下使用数据迁移

    启用数据迁移 在程序包管理控制台选择安装了EntityFramework的项目,键入如下指令以启EF用数迁移. Enable-Migrations 命令成功运行后,所选项目下会添加名为Migratio ...

  5. 【原创】vim插件安装简介

    一.安装vundle(vim插件管理软件): git clone https://github.com/VundleVim/Vundle.vim 拷贝目录到 ~/.vim/bundle/Vundle. ...

  6. 【QTP专题】03_Add-in Manager插件

    1.什么是Add-in Manager Add-in Manager,故名思议这是一个QTP插件管理器,每次启动前需要选择对应的插件才能进行测试. 打开QTP之后,我们可以看到有如下的一个Add-in ...

  7. UI Automator Viewer的使用

    uiautomatorviewer是android SDK自带的工具.通过截屏并分析XML布局文件的方式,为用户提供控件信息查看服务.该工具位于SDK目录下的tools\bin子目录下.可以看到,它是 ...

  8. Java之static静态代码块

    Java之static静态代码块 构造代码块 使用{}包裹的代码区域,这里的代码区域特指位于class{}下面的而不是存在于其他type method(){}这类函数下面的代码区域 public cl ...

  9. win10环境下搭建虚拟环境和 virtualenvwrapper-win 使用

    1. 安装 virtualenv pip install virtualenv 2. virtualenv基本操作 cd path/dir # 跳转到dir目录 virtualenv env # 在d ...

  10. easyui里面的加载tree的两种方式

    第一种: 使用EasyUI中Tree 符合EasyUI中Tree的Json格式,我们先看一下,格式是如何的 [{ "id":1, "text":"My ...