通过前2节的学习,基本掌握了Ext的语法和运行原理,可以作出一些简单的应用。本节我们一起来完成复杂点的对话框操作,因为在实际项目中经常要用到确认对话框等多种操作,然后根据客户的选择作出不同的响应。

一、常见的复杂对话框

常见的复杂点的确认对话框有这么几种,如下图:

效果一:选择确认

效果二:反馈对话框

效果三:多行文本反馈确认

效果四:多按钮选择

效果五:进度条

二、Ext弹出窗体思路

效果一

如上图效果一,是一个很简单的选择确认对话框,弹出的思路也比较简单,和传统的JS一样使用的是Confirm函数,但是在Ext中这些对话框被统一归结到Message下面。所以实现起来只有一句话:“Ext.MessageBox.confirm("选择框","你到底是选yes还是no?");”,第一个参数是对话框的标题,后面是对话框消息正文。

全部代码如下:

<script type="text/javascript"> 
function start(){ 
Ext.MessageBox.confirm("选择框","你到底是选yes还是no?"); 

Ext.onReady(start); 
</script>

如果为其提供一个回调函数,则该函数将在单击按钮后被调用(包括右上角的退出按钮),所单击按钮的id将被作为唯一的参数传递到回调函数中。使用方法是在confirm的参数第三个位置加上回调函数名,然后下面完成这个回调函数,定义一个参数接收用户的选择结果,然后可以根据选择来作出判断,全部代码如下:


<script type="text/javascript"> 
function start(){ 
Ext.MessageBox.confirm("选择框", "你到底是选yes还是no?", callback); 
function callback(id) { 
Ext.MessageBox.alert("提示","你选择的是:"+id); 


Ext.onReady(start); 
</script>

再复杂点的判断可以使用JS原生的语法进行判断,如:


<script type="text/javascript"> 
function start(){ 
Ext.MessageBox.confirm("选择框", "你到底是选yes还是no?", callback); 
function callback(id) { 
if (id == "yes") { 
Ext.MessageBox.alert("提示","你点了确定"); 
} else { 
Ext.MessageBox.alert("提示", "你点了取消?"); 



Ext.onReady(start); 
</script>
效果二

效果二完成的是一个带输入的确认对话框,用的是prompt,和上个效果一样,也需要定义回调函数用来接收用户操作的结果,同时还有用户输入的内容。本例完成一个请求用户输入,如果输入并点击了“确定”则弹出提示“你输入的是…”,而如果没有输入直接取消了,就弹出“你取消了输入!”,完整代码如下:


<script type="text/javascript"> 
function msg() { 
Ext.MessageBox.prompt("提示", "随便写点什么吧!", callback); 
function callback(id, text) { 
if (id == "ok") { 
Ext.MessageBox.alert("提示","你输入的是?:" + text); 
} else { 
Ext.MessageBox.alert("提示","你已经取消了输入!"); 



Ext.onReady(msg); 
</script>
效果三

带多行文本输入框的对话框,这个例子实现思路需要变化一下,使用自定义对话框,原因是原生JS中本来就没有多行文本框这一说。而且接收返回值的思路需要变化。具体代码如:


<script type="text/javascript"> 
function msg() { 
Ext.MessageBox.show({ 
title: '标题', msg: '要显示的内容', 
width: 300, buttons: Ext.MessageBox.OKCANCEL, 
multiline: true, 
fn: callback//这个是Ext专属属性,用来指示处理函数名 
}); 
function callback(id, text) { 
Ext.MessageBox.alert(text); 


Ext.onReady(msg); 
</script>

本例判断省略,和上个例子判断思路一致。

效果四

这个效果是可以显示多个按钮供客户选择,用于多条件处理的情况。


<script type="text/javascript"> 
function msg() { 
Ext.MessageBox.show({ 
title: '标题', msg: '要显示的内容', 
buttons: { yes: true, no: true, cancel: true }, 
// buttons: { yes: "是啊", no: "不啊", cancel: "取消了啊" }, 
fn: callback//这个是Ext专属属性,用来指示处理函数名 
}); 
function callback(id) { 
Ext.MessageBox.alert("提示","你选择的是"+id); 


Ext.onReady(msg); 
</script>
效果五

关于进度条,有两种实现思路,一是按大小确定,一是按时间确定。本例完成按大小控制进度条,完整代码如下:


<script type="text/javascript"> 
function msg() { 
Ext.MessageBox.show({ 
title: '请稍等', 
msg: '加载中...', 
width: 300, 
progress: true, 
closable: false 
}); 
var f = function (v) { 
return function () { 
if (v == 12) { 
Ext.MessageBox.hide(); 
Ext.MessageBox.alert('完成', '加载完毕!'); 
} else { 
var i = v / 11; 
Ext.MessageBox.updateProgress(i, Math.round(100 * i) + '% 已经完成!'); 

}; 
}; 
for (var i = 1; i < 13; i++) { 
setTimeout(f(i), i * 500); 


Ext.onReady(msg); 
</script>

本例进度条是模拟操作,在具体项目中,如文件上传需要实时判断,在后续的课程中详细探讨,进度条不是今天的重点,今天重点讲述自定义对话框的用法。

三、总结:

自定义对话框可以帮助我们完成一些相对复杂的操作,比如获取用户的选择等,另外,自定义对话框也可以定义对话框的图标,只需要加上:“icon:Ext.MessageBox.INFO,//显示图标”,即可。同时也可以自定义图标,显示成你需要的图片,如下效果:

实现思路是:

1. 先定义一个类样式,指定背景图片地址和不平铺;

2. 在icon属性中引入类样式名;

本节代码下载

Ext入门学习系列(三)复杂自定义窗体的更多相关文章

  1. Ext入门学习系列(二)弹出窗体

    第二章 弹出窗体 上节学习了Ext的环境搭建和最基本的一个操作——弹出对话框,作为一个引子,本节讲述如何弹出一个新窗体,从实例讲解Ext的基本运行原理. 一.Ext的窗体长什么样? 先来看看几个效果, ...

  2. Ext入门学习系列(四)面板控件

    第四章 使用面板 上节学习了Ext复杂对话框,更进一步了解了Ext的运行机制.本章重点来了解Ext所有控件的基础——面板控件. 一.Ext的面板是什么? 同样先来看看几个效果: 基本面板,点击右上角小 ...

  3. Ext入门学习系列(五)表格控件(1)

    上节学习了Ext面板控件,为后面的各个控件学习奠定基础,在此基础上本章将学习网络开发最期待的功能——表格控件. 我们都知道网络编程语言中,除了.net其他的基本没有提供网格控件,而最近的asp.net ...

  4. Ext入门学习系列(五)表格控件(3)

    上节学习了Ext中如何绑定服务器端传递的数据.分别用asp.net和asp.net MVC.PHP.XML为例.本节主要介绍绑定之后的分页功能. 一.Ext的表格控件如何绑定? 分页是Ext自带的一个 ...

  5. Ext入门学习系列(五)表格控件(2)

    上节学习了Ext中表格控件,从创建,到定义数据源.绑定显示,大体明白了一个基本的表格控件是怎么实现的.而我们用表格控件多用于从各种数据源接收数据并显示出来,并不是写死的.本章我们就不同数据源的不同实现 ...

  6. VSTO之旅系列(三):自定义Excel UI

    原文:VSTO之旅系列(三):自定义Excel UI 本专题概要 引言 自定义任务窗体(Task Pane) 自定义选项卡,即Ribbon 自定义上下文菜单 小结 引言 在上一个专题中为大家介绍如何创 ...

  7. Asp.Net MVC5入门学习系列⑥

    原文:Asp.Net MVC5入门学习系列⑥ 接着上次的篇幅,我们这篇手动来写一个查询的流程代码! 搜索/查询 流程功能的实现 那现在要做搜索(查询)功能我们第一步应该做什么呢!第一次是不是我们应该去 ...

  8. Asp.Net MVC5入门学习系列①

    原文:Asp.Net MVC5入门学习系列① 现在直接开始MVC5的学习系列,学习资源来自Micrsoft. 开始使用Asp.Net MVC 5 打开Visual Studio 2013,然后新建一个 ...

  9. Asp.Net MVC5入门学习系列⑦

    原文:Asp.Net MVC5入门学习系列⑦ 接着上篇结尾所说,如果开发中刚才遇到Model需要添加或者减少字段/属性的话,但是刚好你也利用EF的Code frist通过Model生存的数据库,这时改 ...

随机推荐

  1. IPHONE开发知识

    IPHONE开发知识http://www.cnblogs.com/valensoft/archive/2010/06/09/1754836.htmlhttp://www.cocoachina.com/ ...

  2. 【Passport】微软过时的技术

    虽然已过时,没来得及体验,摘录一段别人的文章,假装对passport的了解 微软在过去的身份验证服务上,一直采用的Passport验证,但已经是N年前推出来的一个软件架构,当然也被软件界很多地方采用到 ...

  3. Asp.Net MVC过滤器小试牛刀

    在上学期间学习的Asp.Net MVC,基本只是大概马马虎虎的了解,基本处于知其然而不知其所以然.现在到上班,接触到真实的项目,才发现还不够用,于是从最简单的过滤器开始学习.不得不说MVC的过滤器真是 ...

  4. WebApi2 jsonp跨域问题

    一:故事背景     以前在写WebApi2的时候,一直是用作前后端分离(WebApi2 +angularjs),可是最近自己在给WebApp写接口的时候遇到了很多坑,总结一下就是跨域问题.而跨域问题 ...

  5. Linux桌面扩展 Docky

    Docky是从GNOME Do项目剥离出来的一个Dock软件,最初即为GNOME Do的“Docky”模式. 后来开发者觉得,GNOME Do是个快速启动工具,弄个Docky模式有点不伦不类,于是,D ...

  6. ExtJS4.2学习(六)表格分页与通过后台脚本获得分页数据

    鸣谢:http://www.shuyangyang.com.cn/jishuliangongfang/qianduanjishu/2013-11-12/175.html --------------- ...

  7. setjump 和 longjump

    goto语句可以用于同一个函数内异常处理,不幸的是,goto是本地的,它只能跳到所在函数内部的标号上.为了解决这个限制,C函数库提供了setjmp()和longjmp()函数,它们分别承担非局部标号和 ...

  8. POJ2187Beauty Contest

    http://poj.org/problem?id=2187 题意 :有一个农场有N个房子,问最远的房子相距多少距离 . 思路 :凸包,旋转卡壳,通过寻找所有的对锺点,找出最远的点对. #includ ...

  9. hdu 4577 X-Boxes 大数

    java水过…… 代码如下: import java.math.*; import java.util.*; public class Main { public static void main(S ...

  10. SwapEffect 枚举(定义交换效果)

    由于创建设备时要用到这个值,所以在这里总结一下,以免以后再找. 首先引自msdn: Copy 只能为构成单个后台缓冲区的交换链指定此交换效果. 无论交换链是有窗口的还是全屏的,运行库都保证 Devic ...