一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - C# - C# TextBox數(shù)據(jù)綁定的方法

C# TextBox數(shù)據(jù)綁定的方法

2022-03-01 14:20五維思考 C#

這篇文章主要為大家詳細(xì)介紹了C# TextBox數(shù)據(jù)綁定的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

經(jīng)常寫(xiě)用一個(gè)TextBox顯示某個(gè)對(duì)象,然后編輯之后再保存的程序。以前都是在TextBox_TextChanged事件中修改對(duì)象的值,或者保存的時(shí)候再讀取TextBox.Text屬性保存對(duì)象的值。這樣比較麻煩,而且經(jīng)常容易出錯(cuò)。后來(lái)了解了C#的數(shù)據(jù)綁定,發(fā)現(xiàn)能夠很好的解決這個(gè)問(wèn)題。

1. 首先C#的TextBox本身就帶數(shù)據(jù)綁定功能。

下面的代碼就是把_myData對(duì)象的"TheValue"屬性綁定到textBox1和textBox2的"Text"屬性。最后一個(gè)參數(shù)不同:

1)其中DataSourceUpdateMode.OnPropertyChanged表示textBox1.Text發(fā)生變化,_myData.TheValue也變化,叫雙向綁定。

2)DataSourceUpdateMode.Never表示Text1.Text變化不影響_myData.TheValue的值,是單向綁定。

?
1
2
3
4
5
6
private void Form1_Load(object sender, EventArgs e)
{
  _myData = new MyData();
  textBox1.DataBindings.Add("Text", _myData, "TheValue", false, DataSourceUpdateMode.OnPropertyChanged);
  textBox2.DataBindings.Add("Text", _myData, "TheValue", false, DataSourceUpdateMode.Never);
}

2.也許有人留意到了,為什么上面的叫"雙向綁定"呢?如果_myData.TheValue的值變化了,兩個(gè)文本框的Text會(huì)變化嗎?不錯(cuò),僅在 textBox上數(shù)據(jù)綁定還不叫雙向綁定,對(duì)象數(shù)據(jù)變化要通知綁定該對(duì)象的控件才行。這樣就需要對(duì)象實(shí)現(xiàn)INotifyPropertyChanged接 口。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
public class MyData : INotifyPropertyChanged
{
  private string _theValue = string.Empty;
 
  public string TheValue
  {
    get { return _theValue; }
    set
    {
      if (string.IsNullOrEmpty(value) && value == _theValue)
        return;
 
      _theValue = value;
      NotifyPropertyChanged(() => TheValue);
    }
  }
 
  public event PropertyChangedEventHandler PropertyChanged;
 
  public void NotifyPropertyChanged<T>(Expression<Func<T>> property)
  {
    if (PropertyChanged == null)
      return;
 
    var memberExpression = property.Body as MemberExpression;
    if (memberExpression == null)
      return;
 
    PropertyChanged.Invoke(this, new PropertyChangedEventArgs(memberExpression.Member.Name));
  }
}

3.好了,數(shù)據(jù)綁定完成了,看看效果吧。textBox1.Text變化—>_myData.TheValue變化—>textBox2.Text變化。反過(guò)來(lái)textBox2.Text變化就不是這樣了,因?yàn)閠extBox2使用的單向綁定。

C# TextBox數(shù)據(jù)綁定的方法

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://www.cnblogs.com/zhaoshujie/p/9678899.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品国产香蕉在线观看网 | 小货SAO边洗澡边CAO你动漫 | 狠狠综合久久综合网站 | 久久电影精品久久99久久 | 黄 色 大 片 网站 | 久久视频在线视频 | 暖暖的视频完整视频韩国免费 | 久久婷婷五月综合色丁香 | 亚洲激情欧美 | 国产好深好硬好爽我还要视频 | 精品一区二区国语对白 | 欧美成人乱弄视频 | 国产普通话对白露脸流出 | 国产午夜免费视频 | 国产亚洲玖玖玖在线观看 | 国内外成人在线视频 | 日韩视频在线精品视频免费观看 | 精品国产日韩亚洲一区在线 | 国产亚洲一欧美一区二区三区 | 青春娱乐国产分类精品二 | 日韩高清一区 | 亚洲乱亚洲乱妇41p国产成人 | 欧美一区二区三区精品国产 | 操动漫美女视频 | free性俄罗斯护士 | 女人日男人 | 亚洲一区二区三区深夜天堂 | 国产免费资源高清小视频在线观看 | 国产福利你懂的 | 女烈受刑重口小说 | 国产大片免费在线观看 | 免费看黄色片的网站 | 好大好硬好深好爽想要小雪 | 歪歪视频在线播放无遮挡 | 日韩精品一区二区三区免费视频 | 精品国产乱码久久久久久免费 | 末代皇帝无删减版在线观看 | 九哥草逼网| 欧美特级特黄a大片免费 | 精品国产国产精2020久久日 | 91麻豆国产福利精品 |