`

[ExtJS2.1教程-5]ToolBar(工具栏)

    博客分类:
  • ext
EXT 
阅读更多
面板中可以有工具栏,工具栏可以位于面板顶部或底部,Ext中工具栏是由Ext.Toolbar类来表示。工具栏上可以放按钮、文本、分隔符等内容。面板对象中内置了很多实用的工具,可以直接通过面板的tools配置选项往面板头部加入预定义的工具栏选项。

这里工具栏主要用于面板中(panel,window等)
这里我们使用toolbar.js toolbar.html来进行演示

下面我们演示一下在window中应用工具栏
我们先创建一个window
Ext.onReady(function(){
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体"
	});
	win.show();
});


我们可以看到右上角有一个关闭按钮 那其实就是一个头部工具栏按钮
window中有一个tools的配置选项,他的作用就是定义这个头部的工具栏,他接收的是一个数组
数组中的元素包含id,handle等一系列属性,其中id的值是通过Ext事先定义的一系列中选择填入的,handler是对应的响应事件。handler可以传递三个参数 Event,toolEl,panel
Ext.onReady(function(){
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle"
		},{
			id:"close"
		},{
			id:"help"
		}]
	});
	win.show();
});



这里还有一些属性比如qtip,on这里的on很特殊,可以是我们自定义的一些事件 比如鼠标移入等等具体可以参见addListener
这里需要说明的是在使用qtip之前需要调用Ext的qtip初始化方法
Ext.onReady(function(){
	Ext.QuickTips.init();
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle",
			handler:function(e,t,p){
				
				},
			qtip:"hello"
		},{
			id:"close"
		},{
			id:"help"
		}]
	});
	win.show();
});



tbar属性是顶部工具栏,可以有数组和object
我们先来看看ToolBar类,ToolBar的构造方法可以通过object或者数组类型的配置选项进行创建
Ext.onReady(function(){
	Ext.QuickTips.init();
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle",
			handler:function(e,t,p){
				
				},
			qtip:"hello"
		},{
			id:"close"
		},{
			id:"help"
		}],
		tbar:new Ext.Toolbar({
			width:200,
			height:50
		})
	});
	win.show();
});




我们看到这里面得工具栏 不过我们并没有添加工具,下面我们向里面添加一些工具项。
这里我们通过add方法进行添加
Ext.onReady(function(){
	Ext.QuickTips.init();
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle",
			handler:function(e,t,p){
				
				},
			qtip:"hello"
		},{
			id:"close"
		},{
			id:"help"
		}],
		tbar:new Ext.Toolbar({
			width:200,
			height:50
		})
	});
	win.show();
	win.getTopToolbar().add(new Ext.Toolbar.TextItem("titem"))
});

由于只是文本item所以没有什么按钮效果

我们再来加几个
Ext.onReady(function(){
	Ext.QuickTips.init();
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle",
			handler:function(e,t,p){
				
				},
			qtip:"hello"
		},{
			id:"close"
		},{
			id:"help"
		}],
		tbar:new Ext.Toolbar({
			width:200,
			height:50
		})
	});
	win.show();
	win.getTopToolbar().add(new Ext.Toolbar.Fill());
	win.getTopToolbar().add(new Ext.Toolbar.TextItem("titem"));
	win.getTopToolbar().add(new Ext.Toolbar.Button({text:"bitem"}));
	
});


这里Fill很有意思 通过他我们可以实现对齐方式

Ext.onReady(function(){
	Ext.QuickTips.init();
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle",
			handler:function(e,t,p){
				
				},
			qtip:"hello"
		},{
			id:"close"
		},{
			id:"help"
		}],
		tbar:new Ext.Toolbar({
			width:200,
			height:50
		})
	});
	win.show();
	win.getTopToolbar().add(new Ext.Toolbar.Fill());
	win.getTopToolbar().add(new Ext.Toolbar.TextItem("titem"));
	win.getTopToolbar().add(new Ext.Toolbar.Spacer());
	win.getTopToolbar().add(new Ext.Toolbar.Separator());
	win.getTopToolbar().add([new Ext.Toolbar.Spacer(),new Ext.Toolbar.Spacer()]);
	win.getTopToolbar().add(new Ext.Toolbar.Button({text:"bitem"}));
	
});

Spacer是空格 Separator是分隔符 add方法可以是多个参数

当然也可以通过配置选项的方式 不适用new
win.getTopToolbar().add(new Ext.Toolbar.Fill());
win.getTopToolbar().add({xtype:"tbfill"});

上面的两句是等效的
一般我们是不会指定toolbar的宽高,他会自适应
默认toolbar的参数是button
		tbar:new Ext.Toolbar({
			//width:200,
			//height:50
		})
	});
	win.show();
	win.getTopToolbar().add({text:"defButton"});
	win.getTopToolbar().add(new Ext.Toolbar.TextItem("titem"));
	win.getTopToolbar().add(new Ext.Toolbar.Spacer());
	win.getTopToolbar().add(new Ext.Toolbar.Separator());
	win.getTopToolbar().add([new Ext.Toolbar.Spacer(),new Ext.Toolbar.Spacer()]);
	win.getTopToolbar().add(new Ext.Toolbar.Button({text:"bitem"}));


这里的Ext.ToolBar.Button中有一个pressed : Boolean
表示是否显示已按下状态
这里还有一个SplitButton 我们在里面可以看到他有一个menu的配置选项,他可以给我们呈现出下拉菜单按钮
win.getTopToolbar().add({text:"defButton",pressed:true});
	win.getTopToolbar().add(new Ext.Toolbar.TextItem("titem"));
	win.getTopToolbar().add(new Ext.Toolbar.Spacer());
	win.getTopToolbar().add(new Ext.Toolbar.Separator());
	win.getTopToolbar().add([new Ext.Toolbar.Spacer(),new Ext.Toolbar.Spacer()]);
	win.getTopToolbar().add(new Ext.Toolbar.Button({text:"bitem"}));
	
	var menu = new Ext.menu.Menu({
		items:[{
			text:"first"
		},"-",{
			text:"second"
		}]
	})
	win.getTopToolbar().add(new Ext.Toolbar.SplitButton({
		text:"splitbutton",
		menu:menu
	}));



这里需要注意win.getTopToolbar()必须写在win.show()方法之后,因为必须先进行渲染才能取得一些他的一些东西
当然也可以通过window中的tbar:【】进行添加toolbar中的相关信息
Ext.onReady(function(){
	Ext.QuickTips.init();
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle",
			handler:function(e,t,p){
				
				},
			qtip:"hello"
		},{
			id:"close"
		},{
			id:"help"
		}],
		tbar:[new Ext.Toolbar.Spacer(),new Ext.Toolbar.Spacer()]
	});
	win.show();
});

与tbar对应的还有一个bbar只不过位置是在底部,使用上面还是一样的
Ext.onReady(function(){
	Ext.QuickTips.init();
	var win = new Ext.Window({
		width:400,
		height:300,
		title:"窗体",
		tools:[{
			id:"toggle",
			handler:function(e,t,p){
				
				},
			qtip:"hello"
		},{
			id:"close"
		},{
			id:"help"
		}],
		tbar:new Ext.Toolbar({
			//width:200,
			//height:50
		}),
		bbar:[new Ext.Toolbar.Button({text:"bitem"})]
	});
	win.show();



  • 大小: 5.2 KB
  • 大小: 5.1 KB
  • 大小: 5.7 KB
  • 大小: 5.2 KB
  • 大小: 5.4 KB
  • 大小: 5.5 KB
  • 大小: 5.5 KB
  • 大小: 6 KB
  • 大小: 5.9 KB
  • 大小: 6.9 KB
分享到:
评论
1 楼 liuxuejin 2011-05-09  
表单元素横排 怎么搞呢??

相关推荐

    Ext中文帮助文档(Ext常见界面源码,及类库方法详解)

    4. 工具栏(Toolbar):用于放置按钮、菜单、分割线等,常与表格、面板等组件一起使用。 5. 面板(Panel):容器组件,可以包含其他组件,有标题、边框、工具栏等特性。 6. 菜单(Menu):提供下拉式选项,可嵌套。 ...

    精通JS脚本之ExtJS框架.part2.rar

    本书共分17章,分别介绍了JavaScript的对象编程、JavaScript浏览器对象模型和事件机制、ExtJS的核心类库和组件、ExtJS的事件处理方式、设计进度条、设计工具栏和菜单栏、设计面板、设计表格、设计表单、设计数据表、...

    ExtJSWeb应用程序开发指南(第2版)

    2.1 认识ExtJS的开发包 2.2 也从Helloworld开始 2.3 ExtJS中的基本概念 2.4 非常有用的开发工具 2.4.1 开发插件spket 2.4.2 FullSource 2.4.3 MicrosoftScriptDebugger 2.5 ExtJS对原有JavaScript对象的扩展 ...

    老师整理的extjs学习笔记

    `Ext.toolbar.Toolbar` 是用于创建工具栏的组件。它通常包含按钮、分隔符、文本框等控件。下面是一个简单的 `Ext.toolbar.Toolbar` 示例: ```javascript new Ext.Toolbar({ items: [ '->', { xtype: 'tbtext',...

    精通JS脚本之ExtJS框架.part1.rar

    本书共分17章,分别介绍了JavaScript的对象编程、JavaScript浏览器对象模型和事件机制、ExtJS的核心类库和组件、ExtJS的事件处理方式、设计进度条、设计工具栏和菜单栏、设计面板、设计表格、设计表单、设计数据表、...

    Jxstar系统管理手册V2.0.pdf

    - ToolBar:工具栏,展示业务功能操作按钮; - TreePanel:树形控件,用于显示层次结构的数据; - GridPanel:表格控件,用于展示数据列表; - FormPanel:表单控件,用于输入和提交数据。 1.3 高级控件 系统还提供...

    Ext组件描述,各个组件含义

    - **功能描述**:Toolbar 是一个包含按钮、文本框等控件的工具栏。 - **主要用途**:为用户提供快速访问常用功能的方式。 **2.16 Form Panel (Ext.FormPanel)** - **xtype**: `form` - **功能描述**:Form Panel ...

    Ext Js权威指南(.zip.001

    2.1 获取ext js 4 / 34 2.2 配置使用ext js库 / 35 2.3 编写“hello world”程序 / 37 2.4 关于ext.onready / 38 2.5 关于ext.blank_image_url / 40 2.6 关于字体 / 42 2.7 ext js 4语法 / 42 2.8 本地化 / ...

Global site tag (gtag.js) - Google Analytics