数据绑定之Binding双向绑定

Xaml代码

 <!-- Binding双向绑定 -->
 <StackPanel Name="stackPanel" HorizontalAlignment="Left" VerticalAlignment="Top" Orientation="Vertical">
        <TextBox Name="lbId" Text="{Binding ID}"/>      //使用Binding绑定ID属性
        <TextBox Name="lbName" Text="{Binding Name}"/>  //使用Binding绑定Name属性
        <TextBox Name="lbAge" Text="{Binding Age}"/>    //使用Binding绑定Age属性
        <Button Width="100" Height="50" Content="加1" Click="Button_Click"/>
 </StackPanel>

C#代码

    public MainWindow()
    {
        InitializeComponent();
        Init();
    }
    StudentData stuData = new StudentData();  //实例类
    public void Init()
    {
        stuData.ID = 1001;
        stuData.Name = "小明";
        stuData.Age = 18;
        stuData.Name = "小明";
        //this.DataContext = stuData;       //整个窗口内的所有元素都可以绑定此数据
        stackPanel.DataContext = stuData;  //仅stackPanel内的所有元素可以绑定此数据  
    }
    //声明类
    private void Button_Click(object sender, RoutedEventArgs e)
    {
        stuData.Age++;
        MessageBox.Show(stuData.Age.ToString());
    }
}
//引用INotifyPropertyChanged接口,微软双向机制,通知客户端属性值已更改。
public class StudentData:INotifyPropertyChanged
{
    private int _ID;            //声明字段
    private String _Name;       //声明字段
    private int _Age;           //声明字段
    public int ID
    {
        get
        {
            return _ID;
        }
        set
        {
            this._ID = value;
            if (PropertyChanged !=null)
            {
                PropertyChanged(this, new PropertyChangedEventArgs("ID"));
                //如果PropertyChanged状态改变了,响应绑定数据更新
            }
        }
    }
        public String Name
        {
            get
            {
                return _Name;
            }
            set
            {
                this._Name = value;
                if (PropertyChanged != null)
                {
                    PropertyChanged(this, new PropertyChangedEventArgs("Name"));
                }
            }
        }
        public int Age
        {
            get
            {
                return _Age;
            }
            set
            {
                this._Age = value;
                if (PropertyChanged != null)
                {
                    PropertyChanged(this, new PropertyChangedEventArgs("Age"));
                }
            }
        }
        public event PropertyChangedEventHandler PropertyChanged;
}

这里写图片描述
这里写图片描述
“`

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LADT-LINZI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值