zoukankan      html  css  js  c++  java
  • ASPxComboBox筛选问题(不包含简拼全拼搜索)

    主要记录下由输入法引起的筛选问题,先写下用到的属性(Native是额外的了解):

    • Native:组合框控件是否呈现为标准的HTML下拉列表框,true:是,false:否,默认为false;
    • IncrementalFilteringMode:根据输入框中的文本动态筛选过滤列表选项,None:无筛选功能,默认值为None
      • None:无筛选功能,默认值为None
      • StartsWith:搜索从字符串开头开始,搜所得首个字符非开头字符会无搜索结果
      • Contains:搜索从任意字符开始都可以
    • DropDownStyle:获取或设置一个值,该值指定终端用户更改组合框编辑器的编辑值的方式,默认为DropDownList
      • DropDown:用户可以从下拉列表中选择编辑器的值允许从下拉框选值,也可以手动输入值
      • DropDownList:用户只可以从下拉列表中选择编辑器的值

    先贴代码:

     function onValueChange(s, e) {
                if (s.GetSelectedIndex() == -1) {
                    s.SetValue(s.lastChangedValue);
                    return;
                }
            }
            <h4>不可筛选</h4>
            <span>Native="true":组合框控件呈现为标准的HTML下拉列表框,默认为false</span><br />
            <dxe:ASPxComboBox ID="ASPxComboBox1" Width="200" ClientInstanceName="ASPxComboBox1"
                runat="server" ValueField="Code" TextField="Name" Native="true">
            </dxe:ASPxComboBox><br />
            <span>Native="true",默认为false</span>
            <dxe:ASPxComboBox ID="ASPxComboBox2" Width="200" ClientInstanceName="ASPxComboBox2"
                runat="server" ValueField="Code" TextField="Name" Native="false">
            </dxe:ASPxComboBox>
    
            <h4>可以文字筛选(未考虑简拼全拼筛选)</h4>
            <dxe:ASPxComboBox ID="ASPxComboBox3" Width="200" ClientInstanceName="ASPxComboBox3"
                runat="server" ValueField="Code" TextField="Name"
                IncrementalFilteringMode="Contains">
            </dxe:ASPxComboBox>
    
            <h4>可以文字筛选(未考虑简拼全拼筛选,输入法引起的筛选异常)</h4>
            <dxe:ASPxComboBox ID="ASPxComboBox4" Width="200" ClientInstanceName="ASPxComboBox4"
                runat="server" ValueField="Code" TextField="Name"
                DropDownStyle="DropDown" IncrementalFilteringMode="Contains">
                <ClientSideEvents SelectedIndexChanged="onValueChange" />
            </dxe:ASPxComboBox>

    Native属性的效果:

    添加筛选功能,要用到IncrementalFilteringMode属性。当值为DropDownList时,有些输入法在拼音输入时文本直接落在文本框内,DropDownList要求文本框内的值要与列表内的选项匹配才能存活于文本框内,否则就会被自动清除,所以我们拼音输入法搜索时能搜到但界面效果不好,看不到输入的文本。

     当值为DropDown时效果还是不错的,可以输入非列表选项里的值,如果只允许文本框里的值必须包含在下拉列表里,可以添加事件ClientSideEvents,用函数onValueChange控制,若不存在下拉列表里,赋值为空或者之前的选项(例中为之前的选项)

  • 相关阅读:
    050医疗项目-模块五:权限设置-第三方系统的接入
    049医疗项目-模块五:权限设置
    047医疗项目-模块四:采购单模块—采购单审核提交(Dao,Service,Action三层)
    046医疗项目-模块四:采购单模块—采购单审核(Dao,Service,Action三层)
    Netty原理分析
    Java集群优化——使用Dubbo对单一应用服务化改造
    知乎问答:现在程序员的工资是不是被高估了?
    一文理解 Java NIO 核心组件
    深入理解 Spring 事务原理
    完美主义对程序员的影响
  • 原文地址:https://www.cnblogs.com/HapetyPing/p/13431259.html
Copyright © 2011-2022 走看看