【WPF】MVVM前台绑定一组RadioButton按钮
来源:互联网 发布:广州小孩学编程 编辑:程序博客网 时间:2024/05/28 06:08
需求:制作一组RadioButton,像下面这样的效果:
【MVVM】要显示一组RadioButton按钮,想法是Controller层联网获取到数据后,将数据进行处理,然后加到一个ObservableCollection集合中(或者List集合),然后前台准备一个列表控件,绑定这个集合。
最初想法是前台使用一个ItemsControl控件,然后设置它的DataTemplate,大致如下:
<ItemsControl x:Name="areaIC" ItemsSource="{Binding AreaNumList}"> <ItemsControl.ItemTemplate> <DataTemplate> <RadioButton Content="{Binding areaVal}" GroupName="area" Style="{StaticResource myRadioButton2}"/> </DataTemplate> </ItemsControl.ItemTemplate></<ItemsControl>
然后,运行后看不到这组按钮,但可以点击。去掉Style属性就只能显示RadioButton左边的圆圈,右边文字Content内容为空,而且按钮组无法切换,问题很多。。。。。
搜了一下解决方案,看到下面这个:
http://stackoverflow.com/questions/5891924/wpf-mvvm-radio-buttons-on-itemscontrol
根据老外的建议,应该使用ListBox而不是ItemsControl ,并且还得设置各种依赖属性的数据源,最后改为如下:
<ListBox x:Name="areaLB" ItemsSource="{Binding AreaNumList}" SelectedItem="{Binding SelectedItem}" BorderThickness="0" Background="White"> <ListBox.ItemTemplate> <DataTemplate> <RadioButton x:Name="radioBtn" FontSize="14" GroupName="area" Style="{StaticResource myRadioButton2}"> <RadioButton.IsChecked> <Binding Path="IsSelected" RelativeSource="{RelativeSource AncestorType=ListBoxItem}" Mode="TwoWay" /> </RadioButton.IsChecked> <RadioButton.Content> <Binding Path="Content" RelativeSource="{RelativeSource AncestorType=ListBoxItem}" Mode="TwoWay" /> </RadioButton.Content> </RadioButton> </DataTemplate> </ListBox.ItemTemplate></ListBox>
0 0
- 【WPF】MVVM前台绑定一组RadioButton按钮
- WPF MVVM 绑定RadioButton数据
- WPF-MVVM双向绑定
- wpf 在MVVM模式下开发时,怎样让一个属性绑定到多个RadioButton上
- WPF MVVM 绑定ComboBox数据
- WPF 前台处理绑定字段
- 关于WPF RadioButton和CheckBox绑定问题
- WPF利用radiobutton制作菜单按钮
- WPF+MVVM数据绑定问题集锦
- WPF+MVVM数据绑定问题集锦
- WPF--MVVM之DataGrid数据源绑定
- MVVM WPF 使用 datagrid 绑定 comboBox
- 实现动态绑定一组图片按钮
- 潘鹏整理WPF(3)按钮Button&&CheckBox&&RadioButton
- Mvvm Light Toolkit for wpf/silverlight系列之数据绑定
- Mvvm Light Toolkit for wpf/silverlight系列之数据绑定
- WPF MVVM绑定DateGrid的列的显隐性解决方案
- MVVM设计模式和WPF中的实现 (事件绑定)
- h5的socket
- 安卓软键盘修改以及Editetext得失焦点回调
- python -- 字符异或交换
- 哈理工 1812 小乐乐想出门
- socket.io.js
- 【WPF】MVVM前台绑定一组RadioButton按钮
- CVE-2016-7200&7201源码分析
- Leetcode-53. Maximum Subarray
- 根据图片url写入图片到制定位置
- arukas 的 Endpoint
- LeetCode 448. Find All Numbers Disappeared in an Array
- 2.系统开发基础-软件开发方法(2)
- CONCAT(字符串连接函数)和GROUP_CONCAT的一个例子
- 栈的解析及C++实现