日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

WPF綁定Binding用法_基礎(chǔ)應(yīng)用

作者:痕跡g ? 更新時(shí)間: 2022-04-08 編程語(yǔ)言

什么是綁定(Binding)?

在winform中, 我們常常會(huì)用到各種類(lèi)型的賦值, 例如:

  • button1.Text="Hello";
  • label.Text="Hello";
  • ...

類(lèi)似這種賦值操作, 我們之所以不稱之為綁定, 主要原因是因?yàn)樗麄兇蠖鄶?shù)操作都是一次性的, 無(wú)論是數(shù)據(jù)還是按鈕本身發(fā)生變化,對(duì)兩者而言都是不可見(jiàn)的。

而綁定的概念則側(cè)重于: 兩者的關(guān)聯(lián),協(xié)議與兩者之間的影響。

首先, 從一個(gè)簡(jiǎn)單的例子來(lái)理解什么是綁定。

創(chuàng)建一個(gè)滑塊控件, 并且希望在滑動(dòng)的過(guò)程中, 把值更新到另外一個(gè)靜態(tài)文本上。代碼如下:

在winform中, 我們常規(guī)的做法會(huì)給滑塊創(chuàng)建一個(gè)值改變事件,同時(shí)將滑塊的值賦值給文本。

接下來(lái), 我只需要在靜態(tài)文本中添加一小段綁定的聲明,即可完整原本很復(fù)雜的操作:

Text={Binding ElementName=slider,Path=Value}

  • {Binding }: Binding的聲明語(yǔ)法, 一對(duì)尖括號(hào),開(kāi)頭聲明以Binding 開(kāi)始。
  • ElementName= : 該聲明意為, 設(shè)置元素的名稱
  • Path: 設(shè)置關(guān)聯(lián)元素的位置,上例中設(shè)置為元素的value屬性。

那么該如何理解整句話的意義, 翻譯: 靜態(tài)文本TextBlock的Text屬性將通過(guò)綁定的方式關(guān)聯(lián)到元素名'slider'的value屬性上。

效果圖所示:

可以看到,在滑塊不斷的滑動(dòng)過(guò)程中, TextBlock也在不斷的發(fā)生變化, 說(shuō)明TextBlock已經(jīng)得到了滑動(dòng)滑動(dòng)過(guò)程中的值變化, 這種關(guān)聯(lián), 我們稱之為綁定, 在WPF當(dāng)中, 綁定又分很多種, 而上面這種則是通過(guò)元素綁定的方式。

理解了基礎(chǔ)的綁定之后,然后就是理解綁定的模式。

綁定的模式就類(lèi)似我們商業(yè)中的合作, 是一次性回報(bào)還是持續(xù)獲益, 是否可以單方面終止, 是否具有投票權(quán)等, 在WPF中綁定的模式又分為五種:

  • OneWay(單向綁定) : 當(dāng)源屬性發(fā)生變化更新目標(biāo)屬性, 類(lèi)似上面的例子中, 滑動(dòng)變化更新文本的數(shù)據(jù)。示例:

效果:

  • TwoWay(雙向綁定) : 當(dāng)源屬性發(fā)生變化更新目標(biāo)屬性, 目標(biāo)屬性發(fā)生變化也更新源屬性。

與單向綁定的區(qū)別可以理解為, 前者只能打你,被打者不能還手, 雙向綁定的意思則是: 你敢打我一巴掌,我也能回你一巴掌。示例:

效果:

  • OneTime(單次模式) : 根據(jù)第一次源屬性設(shè)置目標(biāo)屬性, 在此之后所有改變都無(wú)效。

如第一次綁定了數(shù)據(jù)源為0, 那么無(wú)論后面如何改變 2、3、4... 都無(wú)法更新到目標(biāo)屬性上。示例:

效果:

  • OneWayToSource : 和OneWay類(lèi)型, 只不過(guò)整個(gè)過(guò)程倒置。示例:

效果:

  • Default : 既可以是雙向,也可以是單項(xiàng), 除非明確表明某種模式, 否則采用該默認(rèn)綁定

綁定到非元素上

上面的代碼中,使用的綁定方式是根據(jù)元素的方式: ElementName=xxx, 如需綁定到一個(gè)非元素的對(duì)象, 則有一下幾屬性:

  • Source : 指向一個(gè)數(shù)據(jù)源, 示例, TextBox使用綁定的方式用Source指向一個(gè)靜態(tài)資源ABC:

  • RelativeSource : 使用一個(gè)名為RelativeSource的對(duì)象來(lái)根據(jù)不同的模式查找源對(duì)象,

示例, 使用RelativeSource的FindAncestor模式, 查找父元素為StackPanel的Width值

  • DataContext: 從當(dāng)前的元素樹(shù)向上查找到第一個(gè)非空的DataContext屬性為源對(duì)象。

示例, 該示例用后臺(tái)代碼創(chuàng)建一個(gè)只包含Name的類(lèi), Test, 通過(guò)綁定窗口的DataContext上下文:

后臺(tái)代碼綁定簡(jiǎn)單文本與列表

創(chuàng)建一個(gè)PageModel類(lèi), 定一個(gè)ClassName為班級(jí)名稱, 和一個(gè)Students學(xué)生列表, 后臺(tái)代碼:

窗口代碼

效果預(yù)覽

關(guān)于以上, 基本介紹了WPF元素綁定的方式與幾種模式, 接下講的是, WPF中的事件如果通過(guò)綁定的方式和UI分離。盡管WPF中仍然可以兼容winform中的事件模型, 而binding也是MVVM架構(gòu)中的重要組成部分(下節(jié)會(huì)介紹)。

原文鏈接:https://www.cnblogs.com/zh7791/p/11379942.html

欄目分類(lèi)
最近更新