{x:Bind} 綁定(通常指已編譯的綁定)具有出色的性能、提供編譯時對綁定表達式的驗證,並支持通過允許你在作為頁面的部分類生成的代碼文件中設置斷點進行調試。可以在 obj文件夾中找到這些文件,其名稱類似於(適用於 C#)
{x:bind}是隨著UWP被推出而被添加的,可以說是Win10 UWP開發專有擴展。雖然 {x:Bind} 缺少{Binding} 中的一些功能,但它運行時所花費的時間和使用的記憶體量均比 {Binding} 要少,且支持更好的調試。
參照網址:{x:Bind} 標記擴展,GitHub微軟UWP實例之XamlBind
1,{x:Bind} 基本原理
在 XAML 載入時,{x:Bind} 將轉換為你所需的綁定對象,此對象將從數據源上的某一屬性中獲取相關值。綁定對象可以配置為觀察數據源屬性值的更改,並基於這些更改自行刷新。該對象也可以配置為將其自己的值的更改推送回源屬性。
2,{x:bind}{Binding}兩者區別
- {x:Bind} 和 {Binding} 創建的綁定對象在功能上大致等同。
- {x:Bind} 執行編譯時所生成的專用代碼,而 {Binding} 使用通用的運行時對象檢查。
- {x:Bind} 綁定(通常指已編譯的綁定)具有出色的性能、提供編譯時對綁定表達式的驗證,並支持通過允許你在作為頁面的部分類生成的代碼文件中設置斷點進行調試。可以在
obj
文件夾中找到這些文件,其名稱類似於(適用於 C#)<view name>.g.cs
。 - {x:Bind} 不將 DataContext 用作預設源 — 它將改用頁面或用戶控制項本身。因此,它將針對屬性、欄位和方法查找代碼隱藏的頁面或用戶控制項。要向 {x:Bind} 顯示視圖模型,你通常需要將新欄位或屬性添加到代碼隱藏的頁面或用戶控制項。屬性路徑中的步驟由點號分隔 (.),並且可包含多個分隔符以遍歷連續的子屬性。
- 使用 x:Bind 時,無需將 ElementName=xxx 用作綁定表達式的一部分。使用 x:Bind 時,你可以使用元素的名稱作為綁定路徑的第一部分,因為已命名的元素變為表示根綁定源的頁面或用戶控制項內的欄位。
- 事件綁定是編譯綁定的一項新功能。它允許你使用綁定為事件指定處理程式,而無需使其成為代碼隱藏的方法。
- 在將 {x:Bind} 用於數據模板時,需通過設置 x:DataType 值來指示要綁定到的類型,你也可以將類型設置為介面或基類類型,然後按需使用轉換,從而編寫一個完整的表達式。
3,{x:Bind}基本用法
<object property="{x:Bind}" .../> -or- <object property="{x:Bind propertyPath}" .../> -or- <object property="{x:Bind bindingProperties}" .../> -or- <object property="{x:Bind propertyPath, bindingProperties}" .../>
propertyPath | 一個指定綁定的屬性路徑的字元串 |
bindingProperties |
propName=value[, propName=value]* 使用一個名稱/值對語法指定的一個或多個綁定屬性 |
propName | 要在綁定對象上設置的屬性的字元串名稱 |
value | 要將屬性設置為的值。參數的語法取決於要設置的屬性。 |
備註:PropertyPath 為 {x:Bind} 表達式設置 Path。Path 是一個屬性路徑,用於指定要綁定到的(源)屬性、子屬性、欄位或方法的值。你可以明確指出 Path 屬性名稱:{Binding Path=...}
。也可以將其省略:{Binding ...}
。
4,{x:Bind}屬性設置
Path | 屬性路徑 |
Converter | 指定綁定引擎所調用的轉換器對象。轉換器可在 XAML 中設置,但只能在你引用已在 XAML 中的 ResourceDictionary中分配的對象實例時設置。你可以使用資源字典中對該對象的 {StaticResource} 標記擴展引用。 |
ConverterLanguage | 指定轉換器要使用的區域性。(如果你要設置 ConverterLanguage,則還應設置 Converter。)區域性可設置為一個基於標準的標識符。有關詳細信息,請參閱 ConverterLanguage。 |
ConverterParameter | 指定可在轉換器邏輯中使用的轉換器參數。 (如果你要設置 ConverterParameter,則還應設置 Converter。)大多數轉換器使用可從要轉換的傳遞值獲取所有所需信息的簡單邏輯,不需要 ConverterParameter值。ConverterParameter 參數適用於具有多個邏輯的中等高級轉換器實現,這些邏輯可切斷傳入ConverterParameter 的內容。你可以編寫一個轉換器,使用除字元串之外的值,但這種情況並不常見,請參閱ConverterParameter 中的備註,以獲取詳細信息。 |
FallbackValue | 指定要在無法解析源或路徑時顯示的值。 |
Mode | 將綁定模式指定為以下一種字元串:"OneTime"、"OneWay" 或 "TwoWay"。預設值是 "OneTime"。請註意,該值不是{Binding} 的預設值,大多數情況下為"OneWay"。 |
TargetNullValue | 指定要在源值解析但並非顯式 null 時顯示的值。 |
備註:OneTime只作為顯示,OneWay實現了INotifyPropertyChanged的屬性接收狀態變更,TwoWay實現了INotifyPropertyChanged的交互屬性。
5,常見例子
- Text="{x:Bind Employee.FirstName}" 綁定成員
- Text="{x:Bind Model.Employees[0].Name}"綁定集合對象成員
- Text="{x:Bind Model.ManagerProp.ReportsOC[0].Name, Mode=OneTime}"深層次綁定
- Text="{x:Bind Model.Employees[0], Mode=OneTime}"綁定對象自動調用ToString()方法輸出字元串
- Value="{x:Bind Model.IntPropertyDP, Mode=TwoWay, Converter={StaticResource IntToDouble}}"
- Visibility="{x:Bind Model.BoolPropWithINPC, Mode=OneWay, Converter={StaticResource BoolToVisibility}}"
- Text="{x:Bind LocalTextBox.Text.Length, Mode=OneWay}"
- Grid.Column="{x:Bind Model.IntPropWithINPC, Mode=OneWay}"
- Grid.Column="{x:Bind OneTimeSlider3.Value, Mode=OneWay, Converter={StaticResource DoubleToInt}}"
- Text="{x:Bind Background.(SolidColorBrush.Color), FallbackValue='This is my fallback value', Mode=OneWay}"
- Text="{x:Bind NullStringProperty, TargetNullValue='This is a null string property'}"
- Text="{x:Bind Button22.(Grid.Row)}" 綁定附加屬性
- Text="{x:Bind obj.(TextBox.Text)}"obj 為類型對象的屬性,包含一個文本框
- Text="{x:Bind groups3[0].(data:SampleDataGroup.Title)}"groups3 欄位是一個對象字典,必須將其轉換為data:SampleDataGroup
- Click="{x:Bind rootFrame.GoForward}"事件綁定
public void GoForward(object sender, RoutedEventArgs e){}
private void GoForward(){}
private void GoForward(object sender, object e){}
對於事件,目標方法不能重載,而且還必須:
- 匹配事件的簽名。
- 或者沒有任何參數。
- 或者具有相同數量的參數類型,這些參數根據事件參數的類型進行賦值。
在生成的代碼隱藏中,已編譯的綁定將處理事件並將其路由到模型上的對應方法,併在該事件發生時計算綁定表達式的路徑。這意味著,與屬性綁定不同的是,它不跟蹤模型的更改。