今天我將介紹如何對“對話(huà)框”進(jìn)行數據綁定。需求很簡(jiǎn)單,點(diǎn)擊ok按鈕時(shí)使用數據綁定確定用戶(hù)的變更,點(diǎn)擊cancel按鈕時(shí)取消更改
一種方法是當用戶(hù)在對話(huà)框內更改信息時(shí)使用綁定來(lái)更新數據源,如果點(diǎn)擊cancel按鈕則撤銷(xiāo)綁定。不過(guò)我不太喜歡這種cancel的方法,因為數據源需要的只是一個(gè)臨時(shí)的值。而且對話(huà)框啟動(dòng)時(shí)需要記住數據;點(diǎn)擊cancel按鈕時(shí)還需要還原數據,應用程序要想實(shí)現這些功能就需要添加額外的邏輯。這可是個(gè)煩人的事。幸運的是還有個(gè)簡(jiǎn)單的方法:改變UpdateSourceTrigger屬性的值
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
主窗體內包含一個(gè)按鈕,用來(lái)啟動(dòng)對話(huà)框。窗體內的其他標簽用來(lái)顯示數據。程序啟動(dòng)時(shí)標簽里沒(méi)有內容。用戶(hù)打開(kāi)對話(huà)框,在文本框里輸入數據后點(diǎn)擊ok,主窗體內標簽的值就會(huì )用戶(hù)輸入的內容。如果點(diǎn)擊cancel按鈕,標簽的值不會(huì )改變
<Button Click="ShowDialog" Width="100" Height="30">Show Dialog</Button>
<Label Grid.Row="0" Grid.Column="1" Name="Name" Margin="5" Content="{Binding Source={StaticResource source}, Path=Name}"/>
<Label Grid.Row="1" Grid.Column="1" Name="Comment" Margin="5" Content="{Binding Source={StaticResource source}, Path=Comment}"/>
private void ShowDialog(object sender, RoutedEventArgs args)
{
Dialog1 dialog = new Dialog1();
dialog.Owner = this;
dialog.ShowDialog();
}
對話(huà)框包含兩個(gè)文本框和Ok/Cancel按鈕。這兩個(gè)文本框的數據源和彼此的應標簽的數據源相同。下面是話(huà)框的xaml代碼
<TextBox Grid.Row="0" Grid.Column="1" Name="Name" Margin="5" Text="{Binding Source={StaticResource source}, Path=Name, UpdateSourceTrigger=Explicit}"/>
<TextBox Grid.Row="1" Grid.Column="1" Name="Comment" Margin="5" Text="{Binding Source={StaticResource source}, Path=Comment, UpdateSourceTrigger=Explicit}"/>
<Button Click="OKHandler" IsDefault="true" Margin="5">OK</Button>
<Button IsCancel="true" Margin="5">Cancel</Button>
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
Binding類(lèi)的UpdateSourceTrigger屬性允許我們指定觸發(fā)升級數據源的方式。文本框TextProperty屬性對應的UpdateTrigger默認值為”LostFocus”:當TextBox失去焦點(diǎn)時(shí)就會(huì )對數據源進(jìn)行更新。該方式不適合這個(gè)程序。我們只想在用戶(hù)點(diǎn)擊ok按鈕時(shí)才更新數據源。將UpdateSourceTrigger的值改為”Explicit”,這樣我們就可以在ok按鈕的事件里顯示地調用BindingExpression的UpdateSource()方法來(lái)更新數據源了。
private void OKHandler(object sender, RoutedEventArgs args)
{
BindingExpression bindingExpressionName = BindingOperations.GetBindingExpression(Name, TextBox.TextProperty);
bindingExpressionName.UpdateSource();
BindingExpression bindingExpressionComment = BindingOperations.GetBindingExpression(Comment, TextBox.TextProperty);
bindingExpressionComment.UpdateSource();
this.DialogResult = true;
}
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
Ok按鈕的邏輯比較簡(jiǎn)單。但Cancel按鈕更簡(jiǎn)單。我們不關(guān)心數據源的更新,僅僅關(guān)閉窗體就可以了:只要將按鈕的IsCancel屬性設置為true就可以了,不需要進(jìn)行事件的編碼
下面是該程序的截圖:
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
原文地址:How do I implement a data bound dialog box?
<!--[endif]-->
譯者注:Beatriz Costa寫(xiě)本文時(shí)的winfx版本是BETA 1,現在已經(jīng)不能使用了。我改動(dòng)了部分代碼。放在這里供大家下載
代碼下載聯(lián)系客服