博客
关于我
INotifyPropertyChanged 接口
阅读量:415 次
发布时间:2019-03-06

本文共 4030 字,大约阅读时间需要 13 分钟。

INotifyPropertyChanged接口是.NET开发中一个核心的概念,用于在属性值发生更改时通知绑定客户端。这种机制特别有用在数据绑定场景中,确保UI或其他依赖的组件能够及时响应数据变化。

INotifyPropertyChanged的作用

该接口的核心功能是提供属性更改的通知。通过实现该接口,对象可以向其绑定的客户端(如UI控件或其他订阅者)发送通知,告知特定属性的值已发生变化。这对于保持UI的更新和用户体验至关重要。


如何实现INotifyPropertyChanged

要实现INotifyPropertyChanged,对象需要定义一个PropertyChanged事件,并在属性值更改时触发该事件。以下是实现步骤:

  • 定义事件:在类中定义public event PropertyChangedEventHandler PropertyChanged;
  • 提供通知方法:实现NotifyPropertyChanged方法,该方法将触发PropertyChanged事件。
  • 使用CallerMemberName属性:在NotifyPropertyChanged方法中使用[CallerMemberName]属性,可以让事件自动获取属性名称,无需手动传递。

  • 绑定类型的要求

    在数据绑定场景中,绑定类型需要具备以下功能之一:

    • 实现INotifyPropertyChanged接口:这是首选的实现方式,确保属性更改时自动触发通知。
    • 为每个属性提供更改事件:通过直接在属性的set块中调用NotifyPropertyChanged方法。
    • 不要同时实现上述两种功能:选择一种方式即可,避免冗余。

    代码示例

    以下代码展示了如何在C#中实现INotifyPropertyChanged接口。该示例使用了CallerMemberName属性,简化了通知方法的调用。

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Drawing;using System.Runtime.CompilerServices;using System.Windows.Forms;namespace TestNotifyPropertyChangedCS{    public partial class Form1 : Form    {        private Button changeItemBtn = new Button();        private DataGridView customersDataGridView = new DataGridView();        private BindingSource customersBindingSource = new BindingSource();        private BindingList
    customerList = new BindingList
    (); public Form1() { InitializeComponent(); this.changeItemBtn.Text = "Change Item"; this.changeItemBtn.Dock = DockStyle.Bottom; this.changeItemBtn.Click += new EventHandler(changeItemBtn_Click); this.Controls.Add(this.changeItemBtn); customersDataGridView.Dock = DockStyle.Top; this.Controls.Add(customersDataGridView); this.Size = new Size(400, 200); } private void Form1_Load(object sender, EventArgs e) { customerList.Add(DemoCustomer.CreateNewCustomer()); customerList.Add(DemoCustomer.CreateNewCustomer()); customerList.Add(DemoCustomer.CreateNewCustomer()); customersBindingSource.DataSource = customerList; customersDataGridView.DataSource = customersBindingSource; } void changeItemBtn_Click(object sender, EventArgs e) { customerList[0].CustomerName = "Tailspin Toys"; customerList[0].PhoneNumber = "(708)555-0150"; } } public class DemoCustomer : INotifyPropertyChanged { private Guid idValue = Guid.NewGuid(); private string customerNameValue = String.Empty; private string phoneNumberValue = String.Empty; public event PropertyChangedEventHandler PropertyChanged; [CallerMemberName] private void NotifyPropertyChanged([String] String propertyName = "") { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(propertyName)); } } private DemoCustomer() { customerNameValue = "Customer"; phoneNumberValue = "(312)555-0100"; } public static DemoCustomer CreateNewCustomer() { return new DemoCustomer(); } public Guid ID { get { return this.idValue; } } public string CustomerName { get { return this.customerNameValue; } set { if (value != this.customerNameValue) { this.customerNameValue = value; NotifyPropertyChanged(); } } } public string PhoneNumber { get { return this.phoneNumberValue; } set { if (value != this.phoneNumberValue) { this.phoneNumberValue = value; NotifyPropertyChanged(); } } } }}

    总结

    INotifyPropertyChanged接口是.NET开发中一个关键的工具,用于实现属性更改的通知。在实际应用中,建议优先选择实现该接口的方式,以确保绑定客户端能够及时响应数据变化。此外,使用CallerMemberName属性可以简化代码,并提高开发效率。

    转载地址:http://pufkz.baihongyu.com/

    你可能感兴趣的文章
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>
    npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
    查看>>
    npm版本过高问题
    查看>>
    npm的“--force“和“--legacy-peer-deps“参数
    查看>>
    npm的安装和更新---npm工作笔记002
    查看>>
    npm的常用操作---npm工作笔记003
    查看>>
    npm的常用配置项---npm工作笔记004
    查看>>
    npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
    查看>>
    npm编译报错You may need an additional loader to handle the result of these loaders
    查看>>
    npm设置淘宝镜像、升级等
    查看>>
    npm设置源地址,npm官方地址
    查看>>
    npm设置镜像如淘宝:http://npm.taobao.org/
    查看>>
    npm配置安装最新淘宝镜像,旧镜像会errror
    查看>>
    NPM酷库052:sax,按流解析XML
    查看>>
    npm错误 gyp错误 vs版本不对 msvs_version不兼容
    查看>>
    npm错误Error: Cannot find module ‘postcss-loader‘
    查看>>
    npm,yarn,cnpm 的区别
    查看>>
    NPOI
    查看>>
    NPOI之Excel——合并单元格、设置样式、输入公式
    查看>>
    NPOI初级教程
    查看>>