autocomplete控件 java_WPF-15:AutoCompleteBox的使用(实现下拉列表)

下拉列表之前用这种popup控件实现(http://blog.csdn.net/yysyangyangyangshan/article/details/8177878),使用起来也比较不方便。好在wpf中还有一个控件AutoCompleteBox可以来实现。不过使用之前需要引用System.Windows.Controls.Input.Toolkit.dll(最好安装WPF Toolkit,这里就包含了该dll)。本文对应的项目文件中含有该dll( http://download.csdn.net/detail/yysyangyangyangshan/5304822)。

下面直接看代码:

界面:

xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"

xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"

xmlns:tookit="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Input.Toolkit"

Title="MainWindow" Height="350" Width="525">

ValueMemberPath="SerchString" Margin="10"

FontSize="20" Height="50" Foreground="Black">

下拉列表绑定的数据模型类:

///

/// 绑定模型类

///

public class AutoCompleteModel : INotifyPropertyChanged

{

public void OnPropertyChanged(string propname)

{

if (this.PropertyChanged != null)

{

PropertyChanged(this, new PropertyChangedEventArgs(propname));

}

}

public event PropertyChangedEventHandler PropertyChanged;

private string searchString = string.Empty;

private string name = string.Empty;

public string SerchString

{

get { return searchString; }

set

{

searchString = value;

this.OnPropertyChanged("SerchString");

}

}

public string Name

{

get { return name; }

set

{

name = value;

this.OnPropertyChanged("Name");

}

}

}

后台使用:

public partial class MainWindow : Window

{

public MainWindow()

{

InitializeComponent();

this.searchTextBox.Populating += new PopulatingEventHandler(AutoCompleteBox_Populating);

this.searchTextBox.SelectionChanged += new SelectionChangedEventHandler(searchTextBox_SelectionChanged);

}

void searchTextBox_SelectionChanged(object sender, SelectionChangedEventArgs e)

{

AutoCompleteModel model = this.searchTextBox.SelectedItem as AutoCompleteModel;

if (model != null)

{

MessageBox.Show(model.Name);

}

}

private void AutoCompleteBox_Populating(object sender, PopulatingEventArgs e)

{

e.Cancel = true;

List data = new List();

for (int i = 0; i < 10; i++)

{

AutoCompleteModel model = new AutoCompleteModel();

model.SerchString = "1234";

model.Name = "测试" + i;

data.Add(model);

}

this.searchTextBox.ItemsSource = data;

//设置那种模式匹配

this.searchTextBox.FilterMode = AutoCompleteFilterMode.Contains;

this.searchTextBox.PopulateComplete();

}

}

效果图:

00b682dbbeb582e36fcd4288301b1a20.png

注意:

1、AutoCompleteBox中ValueMemberPath="SerchString",要指定查询的字段。

2、 this.searchTextBox.FilterMode = AutoCompleteFilterMode.Contains,需要注意设置搜索时的匹配方式。

代码下载:

http://download.csdn.net/detail/yysyangyangyangshan/5304822

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值