下拉框中optGroup的一个bug

本文介绍了一种解决HTML Select下拉框中OptGroup被误选中的问题的方法,通过JavaScript进行处理,确保不会选中OptGroup,特别适用于只有OptGroup的情况。


当下拉框中的第一项是optGroup时,在用鼠标滚轮改变选项时,如果快速的向上滚动则会把第一项的optGroup选中,这不是我们想要的结果,而且再用代码获取下拉框的值是就会发生错误。

选中optGroup后,下拉框失去焦点后selectIndex的值在此时还是0(当下拉框中有可选项时).只有在下拉框再次获得焦点并失去焦点时selectIndex的值才真正的变为-1,所以简单的在onblur判断selectIndex是不行的,所以我们需要作一个中间的处理,然后判断selectIndex,如果选中的optGroup则把selectIndex置为0.

当下拉框只有optGroup时默认是不选中任何项的,也就是空项,空项的selectIndex的也是-1,所以在这种情况下不能直接把selectIndex置为0(因为没有option项),我不能设置为-1,那样是没有任何效果的,我们需要先向下拉框中添加一个option,把selectIndex设为0,然后再把selectIndex设为-1,再把新加的option删除,因为原则上optGroup是不能选中的,所以把selectIndex设为-1时选中的将是一个空项。

具体代码如下:


<HTML>
<HEAD>
<TITLE> New Document </TITLE>
</HEAD>

<BODY>

<SELECT id="sel" onblur="ValidateElement(this);">
<optgroup label='1111'>
</optgroup>
</SELECT>

<SELECT id="sel1" onblur="ValidateElement(this);">
<optgroup label='1111'>
 <option >12</option >
 <option >23</option >
 <option >34</option >
</optgroup>
 <option >aa</option >
 <option >bb</option >
 <option >cc</option >
</SELECT>

</BODY>
</HTML>
<SCRIPT LANGUAGE="JavaScript">
<!--

 function ValidateElement(obj)
 {
  var t = obj.selectedIndex;
  obj.selectedIndex = -1;
  obj.selectedIndex = t;

  if(obj.selectedIndex == -1)
  {
   if(obj.options.length > 0)
   {
    obj.selectedIndex = -1;
    obj.selectedIndex = 0;
   }
   else
   {
    opt = document.createElement("option");
    opt.innerText = "";
    obj.insertAdjacentElement("beforeEnd",opt);
    obj.selectedIndex = 0;
    obj.selectedIndex = -1;
    try
    {
     obj.options[0] = null;
    }
    catch(e){}
   }
  }
 }

//-->
</SCRIPT> 

 

在不同的技术场景下,从下拉框中选中一个数据有不同的实现方法: ### ActionScript 场景 在 ActionScript 中,可借助 `DataAnalysis` 类的 `listDataMatching` 方法来匹配已选中数据的某字段和下拉框数据,进而选中下拉框中匹配的项,此方法常用于编辑数据时。示例代码如下: ```actionscript package YD.Web.Common.Utils{ import mx.collections.ArrayCollection; public class DataAnalysis { public function DataAnalysis() { } /** * 此函数是匹配已选中数据的某字段和下拉框中的数据,并选中下拉框中匹配的项,多用于编辑数据时<br/> * data: 要匹配的数据源,ArrayCollection或XML<br/> * label: 要匹配的字段<br/> * property: 数据源如果是Object或XML属性,需要填写要匹配的数据源属性,如果是字符串,则不需要填写 **/ public static function listDataMatching(data:Object,label:String,property:String=null):int { if(data is ArrayCollection) { var ac:ArrayCollection = data as ArrayCollection; for(var i:int=0;i<ac.length;i++) { if(property) { if(label == ac[i][property]) return i; } else { if(label == ac[i].toString()) return i; } } } else if(data is XML) { var xml:XML = data as XML; for each(var j:XML in xml.*) { if(label == j.@[property]) return j.childIndex(); } } return -1; } } } // 使用示例 pStateDDL.selectedIndex = DataAnalysis.listDataMatching(productionStateAC,o.productionState,'name'); ``` 这里通过 `DataAnalysis.listDataMatching` 方法找出匹配项的索引,再把该索引赋值给下拉框的 `selectedIndex` 属性,从而选中相应项[^1]。 ### jQuery + EasyUI 场景 在 jQuery + EasyUI 里,能够利用 JavaScript 方法依据第一个下拉框选中的值来确定第二个下拉框的内容。示例代码如下: ```javascript function selectTrayCode(areCode) { var value; var areCode=document.getElementsByName("areaCode").forEach(function(element) { if (element.value != "") { value = element.value } }) var url ="/bas/cargoSpace/listall?roadwayId="+value; var data1 ; $.getJSON(url, function(data) { data1 = data; $('#tray_Code').combobox({ data: data1, valueField: 'cargo_space_id', textField: 'cargo_space_name' }); }); }; ``` 在这个示例中,当第一个下拉框的值改变时,调用 `selectTrayCode` 方法,通过 AJAX 请求获取数据并设置到第二个下拉框中,用户可以从第二个下拉框中选择数据[^2]。 ### Vue + Spring Boot 场景 在 Vue 和 Spring Boot 结合的场景中,第二个下拉框的内容依据第一个下拉框的数据进行选择。示例代码如下: ```java // controller 中的代码段 /** * 查询二级分类列表 */ @PreAuthorize("@ss.hasPermi('backstage:twoCategory:all')") @GetMapping("/all/{oneId}") public AjaxResult all(@PathVariable Long oneId) { List<TTwoCategory> list = tTwoCategoryService.selectTTwoCategoryNameList(oneId); return AjaxResult.success(list); } /** * 查询一级分类列表 */ @PreAuthorize("@ss.hasPermi('backstage:oneCategory:all')") @GetMapping("/all") public AjaxResult all() { List<TOneCategory> list = tOneCategoryService.selectTOneCategoryNameList(); return AjaxResult.success(list); } ``` 在前端 Vue 代码里,可监听第一个下拉框的选择事件,当选中值改变时,调用后端接口获取第二个下拉框的内容,用户就能从第二个下拉框中选择数据[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值