1.ExtJs之消息框:
语法:Ext.MessageBox.alert(String title, String msg,Function fn, Obejct scope); 参数定义:
- title: 标题
- msg: 提示内容
- fn: 提示框关闭之后自动调用的回调函数
- scope: 作用域,用于指定this指向哪里
例如:
ExtJsAlert = function(){
Ext.MessageBox.alert("提示框","这是一个提示框");
}
or
ExtJsAlert = function(){
Ext.MessageBox.alert("提示框","这是一个提示框",function(){
alert("提示框关闭")
});
}
如果要将上面的代码运行,则要将改源码保存JS,然后导入页面中,增加
<input type="button" value="点击" onclick="ExtJsAlert();"/>
2. ExtJs 之输入框
语法:Ext.MessageBox.prompt(String title, String msg,Function fn,Object scope,Boolean/Number multiline);
参数定义:
- title: 标题
- msg: 提示内容
- fn: 提示框关闭之后自动调用的回调函数
- scope: 作用域,用于指定this指向哪里
- Boolean/Number:如果为true或为数字,则表示允许输入多行或者指定默认高度
例如:
ExtJsPrompt = function(){
Ext.MessageBox.prompt("输入框","请输入名字:",function(bu,txt){
Ext.MessageBox.alert("Result","你点击的是"+bu+"按钮,<br> 输入的内容为:"+txt);
});
}
or
ExtJsPrompt = function(){
Ext.MessageBox.prompt("输入框","请输入名字:",function(bu,txt){
Ext.MessageBox.alert("Result","你点击的是"+bu+"按钮,<br> 输入的内容为:"+txt);
},this,300);
}
3.ExtJs之确认框
语法:
Ext.MessageBox.confirm(String title, String msg,Function fn, Object scope);
参数定义:
- title: 标题
- msg: 提示内容
- fn: 提示框关闭之后自动调用的回调函数
- scope: 作用域,用于指定this指向哪里
例如:
ExtJsComfirm = function(){
Ext.MessageBox.confirm("确认","请点击下面的按钮作出选择",function(btn{
Ext.MessageBox.alert("你单击的按钮是:"+btn);
});
}
4. ExtJs之自定义消息框
语法:
Ext.MessageBox.show(Object config); config属性说明:
- title : 消息框标题栏
- msg:消息内容
- width:消息框的宽度
- multiline: 是否显示多行文本
- closable:是否显示关闭按钮
- buttons:按钮
- icon:图标
- fn:回调函数
例如
ExtJsCustom = function(){
var config ={
title:"自定义对话框",
msg:"这是一个自定义对话框",
width:400,
multiline:true,
closable:false,
buttons:Ext.MessageBox.YESNOCANCEL,
icon:Ext.MessageBox.QUESTION,
fn: function(btn,txt){
Ext.MessageBox.alert("Result","你点击了'yes'按钮<br>,输入的值是:"+txt);
}
};
Ext.MessageBox.show(config);
}
注意: 在ExtJs.MessageBox中已经定义了buttons的取值.如下
引用
OK:只有"确定"按钮
CANCEL:只有"取消"按钮
OKCANCEL:有"确定"和"取消"按钮
YESNO: 有"是"和"否"按钮
YESNOCANCEL:有"是"、"否"和"取消"按钮
icons取值如下
引用
INFO:信息图标
WARNING:警告图标
QUESTION:询问图标
ERROR:错误图标
5.ExtJs之进度条对话框
进度条对话框也是自定义消息框的一种,只是在配置Config时添progress=true即可,同时在设置其他相关信息,比如进度提示。
下面看看代码:
ExtJsProgress = function(){
Ext.MessageBox.show({
title:'请等待片刻',
msg:'正在加载项目....',
progressText:'正在初始化...',
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=0; i<13;i++){
setTimeout(f(i),i*500);
}
}
解析上述代码中ProgressText属性是进度条滚动之前最初的文本,滚动进程由updateProgress(Number value,String progressText)方法来定义,参数value是从0-1之间的小数,表示进度百分比;progressText则表示进度条滚动过程中的文本提示信息。
6.ExtJs之消息框动画效果
直接看代码
ExtJsAnimal = funciton(){
var config = {
title:"飞出的消息框",
msg:"这是一个自定义对话框,是飞出来的哦",
width:400,
multiline:true,
closable:false,
buttons:Ext.MessageBox.YESNOCANCEL,
icon:Ext.MessageBox.QUESTION,
animEl:"fly"
};
Ext.MessageBox.show(config);
}
在html代码中加入
<input type="button" value="Animal" id="fly" onclick="ExtJsAnimal();"/>
这里id=fly就是animEL的值