数据绑定

OneTime绑定:单次绑定,绑定后数据改变界面不会发生改变 

 

OneWay绑定:单向绑定,这个是绑定的默认值,当我们改变数据源的值时,界面上面的值会发生改变,但当我们改名界面上面的值时,数据源数据不会发生变化(Eval)

 

TwoWay绑定:双向绑定,任意一方数据改变都会触发数据源或界面上面的值(BIND)

 

slider 进度滚动条

        <TextBox Text="{Binding Value,Mode=TwoWay,ElementName=s1}"/>

        <Slider Maximum="100" Minimum="0" x:Name="s1" Width="299"/>


这个是最基本的一个绑定列子,下面我们看一看把一个对象的属性绑定到控件上面去

首先定义一个类Person

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace GridExp
{
    public class Person : INotifyPropertyChanged
    {
        private string _name;
        private int _age;
        public int Id { get; set; }
        public string Name
        {
            get
            {
                return _name;
            }
            set
            {
                _name = value;
                if (PropertyChanged != null)
                {
                    PropertyChanged(this, new PropertyChangedEventArgs("Name"));
                }
            }
        }
        public int Age
        {
            get
            {
                return _age;
            }
            set
            {
                _age = value;
                if (PropertyChanged != null)
                {
                    PropertyChanged(this, new PropertyChangedEventArgs("Age"));
                }
            }
        }

        public event PropertyChangedEventHandler PropertyChanged;
    }

}

INotifyPropertyChanged接口规定了当属性更改时,向界面发送通知,这个事件时相对于Binding来说的,如果没有Binding,则不起任何作用

然后在前台定义3个控件

    <TextBox Text="{Binding Name}" x:Name="bx" Width="200" Height="50"/><!--把控件的Text属性绑定到数据源的Name属性上-->
        <Button Content="读出Person的值" Click="Button_Click_1"></Button>
        <Button Content="修改Person的值" Margin="400,400,0,0" Click="Button_Click_2"></Button>

后台数据绑定

 private Person p = new Person() { Name = "XXX", Age = 21 };

        public GroupedItemsPage()
        {
            this.InitializeComponent();
        }
        protected override void OnNavigatedTo(NavigationEventArgs e)
        {

            bx.DataContext = p;
        }

        private void Button_Click_1(object sender, RoutedEventArgs e)
        {
            MessageDialog dlg = new MessageDialog(p.Name);
            dlg.ShowAsync();
        }

        private void Button_Click_2(object sender, RoutedEventArgs e)
        {
            p.Name = DateTime.Now.Millisecond.ToString();
        }

 这里需要提一下,就是内层控件会继承外层控件的数据源(数据上下文),也就是说,上面数据绑定的代码如果写成

protected override void OnNavigatedTo(NavigationEventArgs e)
        {

            this.DataContext = p;
        }

也是可以的

 

转载于:https://www.cnblogs.com/zhuzhenyu/archive/2012/12/03/2799539.html

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值