Combobox属性详解

Js代码 
  1. Ext.onReady(function(){   
  2.     //使用表单提示  
  3.     Ext.QuickTips.init();  
  4.     Ext.form.Field.prototype.msgTarget = 'side';//提示显示方式
  5.     /* 
  6.     //定义读取数据映射。 
  7.     var modelRecordDef = Ext.data.Record.create([ 
  8.         {name: 'name'},{name: 'value'} 
  9.     ]);  
  10.     //定义数据源和读取方式 
  11.     //如果不想再页面初始化是加载数据,则可以有以下两种办法: 
  12.     //第一、把comboboxStore.load()去掉。 
  13.     //第二、不要proxy,在需要加载数据的时候再写上:comboboxStore.proxy = new Ext.data.HttpProxy({url: url}) 
  14.     //第二种方法可以灵活的取得下拉框的数据。因为可以变动url. 
  15.     var comboboxStore=new Ext.data.Store({ 
  16.         //下面这句也可以直接写成:url: "../../manageActions/actionAction!getJsons.html", 
  17.         proxy: new Ext.data.HttpProxy({ url: "../../manageActions/actionAction!getJsons.html"}), 
  18.         //传给后台的参数:baseParams的参数是一直存在的,而params的参数,只有load时才会传递过去,当调用reload时参数就不存在了 
  19.         baseParams:{arg:'Model'}, 
  20.         //设定读取的格式 
  21.         reader: new Ext.data.JsonReader({  
  22.             id:"modelCboxId",root:'resultList' 
  23.             }, modelRecordDef), 
  24.         //不排序,此属性为true则设置的所有排序都不起作用。此属性只对从服务器取数据有效。 
  25.         remoteSort: true 
  26.     }); 
  27.     //排序用的列名和排序方式,这个必须在load之前或者下次load时发生。 
  28.     comboboxStore.setDefaultSort('name', 'ASC'); 
  29.     //排序用的列名和排序方式,这个无所谓load位置。 
  30.     comboboxStore.sort('name', 'ASC'); 
  31.     //加载数据。 
  32.     comboboxStore.load(); 
  33.     var Cb = new Ext.form.ComboBox({ 
  34.         fieldLabel: '下拉框',     //显示文本字段 
  35.         valueField:'value',      //下拉框的值域 
  36.         hiddenName:'cb',         //真正提交时此combo的name 
  37.         displayField:'name',     //显示的域 
  38.         id:'CbId',               //id 
  39.         emptyText:'-- 请选择 --', //空文本是显示的值 
  40.         renderTo: 'combobox',    //将此下拉框渲染到id为combobox的div中 
  41.         width:200,               //宽度 
  42.         anchor:'95.2%',          //自适应宽度,随着容器变化而变化。 
  43.         selectOnFocus:true,      
  44.         triggerAction:'all',    //请设置为"all",否则默认为"query"的情况下,你选择某个值后,再次下拉时,只出现匹配选项,如果设为"all"的话,每次下拉均显示全部选项 
  45.         store:comboboxStore,    //下拉框数据来源 
  46.         typeAhead:true,         //延时查询,与下面的参数配合 
  47.         typeAheadDelay:250,     //默认250 
  48.         editable:true,          //是否可编辑 
  49.         forceSelection:true,    //是否只能选择下拉框的值,即不会取输入的未在下拉框值域内的值 
  50.         mode: 'local'           //因为data已经取数据到本地了,所以'local',默认为"remote" 
  51.     }); 
  52.     */  
  53.     //读取本地数据  
  54.     var localStore = new Ext.data.SimpleStore({  
  55.         fields: ["num"],  
  56.         data: [["2"],["1"],["5"],["3"],["9"],["6"]],  
  57.         //排序,只能对本地取数据有效。  
  58.         sortInfo:{field:"num"}  
  59.     });  
  60.     //排序用的列名和排序方式,对于本地数据和服务器取数据一样适用。  
  61.     localStore.sort('num''ASC');  
  62.     var localCb = new Ext.form.ComboBox({  
  63.         store: localStore,  
  64.         renderTo: 'combobox',  
  65.         valueField :"num",  
  66.         displayField: "num",  
  67.         hiddenName:'number',  
  68.         mode: 'local',  
  69.         forceSelection: true,  
  70.         blankText:'-- 请选择 --',  
  71.         emptyText:'-- 请选择 --',  
  72.         editable: true,  
  73.         selectOnFocus:true,  
  74.         triggerAction: 'all',  
  75.         id:'localCombo',  
  76.         anchor:'95.2%',  
  77.         typeAhead: true,  
  78.         fieldLabel: '数字'  
  79.     });  
  80.       
  81.     //把已有的下拉框改变为Ext样式  
  82.     var ExtSelect=new Ext.form.ComboBox({  
  83.             transform:"select",//html中的select控件id  
  84.             width:200          //宽度  
  85.         });  
  86. });  
	Ext.onReady(function(){	
		//使用表单提示
		Ext.QuickTips.init();
		Ext.form.Field.prototype.msgTarget = 'side';//提示显示方式
		
		/*
		//定义读取数据映射。
		var modelRecordDef = Ext.data.Record.create([
			{name: 'name'},{name: 'value'}
		]); 
		//定义数据源和读取方式
		//如果不想再页面初始化是加载数据,则可以有以下两种办法:
		//第一、把comboboxStore.load()去掉。
		//第二、不要proxy,在需要加载数据的时候再写上:comboboxStore.proxy = new Ext.data.HttpProxy({url: url})
		//第二种方法可以灵活的取得下拉框的数据。因为可以变动url.
		var comboboxStore=new Ext.data.Store({
			//下面这句也可以直接写成:url: "../../manageActions/actionAction!getJsons.html",
			proxy: new Ext.data.HttpProxy({ url: "../../manageActions/actionAction!getJsons.html"}),
			//传给后台的参数:baseParams的参数是一直存在的,而params的参数,只有load时才会传递过去,当调用reload时参数就不存在了
			baseParams:{arg:'Model'},
			//设定读取的格式
			reader: new Ext.data.JsonReader({ 
				id:"modelCboxId",root:'resultList'
				}, modelRecordDef),
			//不排序,此属性为true则设置的所有排序都不起作用。此属性只对从服务器取数据有效。
			remoteSort: true
		});
		//排序用的列名和排序方式,这个必须在load之前或者下次load时发生。
		comboboxStore.setDefaultSort('name', 'ASC');
		//排序用的列名和排序方式,这个无所谓load位置。
		comboboxStore.sort('name', 'ASC');
		//加载数据。
		comboboxStore.load();
		var Cb = new Ext.form.ComboBox({
			fieldLabel: '下拉框',     //显示文本字段
			valueField:'value',      //下拉框的值域
			hiddenName:'cb',         //真正提交时此combo的name
			displayField:'name',     //显示的域
			id:'CbId',               //id
			emptyText:'-- 请选择 --', //空文本是显示的值
			renderTo: 'combobox',    //将此下拉框渲染到id为combobox的div中
			width:200,               //宽度
			anchor:'95.2%',          //自适应宽度,随着容器变化而变化。
			selectOnFocus:true,     
			triggerAction:'all',    //请设置为"all",否则默认为"query"的情况下,你选择某个值后,再次下拉时,只出现匹配选项,如果设为"all"的话,每次下拉均显示全部选项
			store:comboboxStore,    //下拉框数据来源
			typeAhead:true,         //延时查询,与下面的参数配合
			typeAheadDelay:250,     //默认250
			editable:true,          //是否可编辑
			forceSelection:true,    //是否只能选择下拉框的值,即不会取输入的未在下拉框值域内的值
			mode: 'local'           //因为data已经取数据到本地了,所以'local',默认为"remote"
		});
		*/
		//读取本地数据
		var localStore = new Ext.data.SimpleStore({
		 	fields: ["num"],
			data: [["2"],["1"],["5"],["3"],["9"],["6"]],
			//排序,只能对本地取数据有效。
			sortInfo:{field:"num"}
		});
		//排序用的列名和排序方式,对于本地数据和服务器取数据一样适用。
		localStore.sort('num', 'ASC');
		var localCb = new Ext.form.ComboBox({
			store: localStore,
			renderTo: 'combobox',
			valueField :"num",
			displayField: "num",
			hiddenName:'number',
			mode: 'local',
			forceSelection: true,
			blankText:'-- 请选择 --',
			emptyText:'-- 请选择 --',
			editable: true,
			selectOnFocus:true,
			triggerAction: 'all',
			id:'localCombo',
			anchor:'95.2%',
			typeAhead: true,
			fieldLabel: '数字'
		});
		
		//把已有的下拉框改变为Ext样式
		var ExtSelect=new Ext.form.ComboBox({
             transform:"select",//html中的select控件id
             width:200          //宽度
         });
	});
Html代码 
  1. <div id="combobox"></div>  
  2.     <select id="select">  
  3.         <option value="1"></option>  
  4.         <option value="2"></option>  
  5.         <option value="3">人妖</option>  
  6.     </select> 

你可能感兴趣的:(html,prototype,ext)