BindingGroup.TryGetValue(Object, String, Object) 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
지정된 속성 및 항목에 대해 제안된 값을 가져옵니다.
public:
bool TryGetValue(System::Object ^ item, System::String ^ propertyName, [Runtime::InteropServices::Out] System::Object ^ % value);
public bool TryGetValue(object item, string propertyName, out object value);
member this.TryGetValue : obj * string * obj -> bool
Public Function TryGetValue (item As Object, propertyName As String, ByRef value As Object) As Boolean
매개 변수
- item
- Object
지정된 속성을 포함하는 개체입니다.
- propertyName
- String
제안된 값을 가져올 속성입니다.
- value
- Object
이 메서드가 반환될 때 제안된 속성 값을 나타내는 개체를 포함합니다. 이 매개 변수는 초기화되지 않은 상태로 전달됩니다.
반환
true값이 지정된 속성에 대해 제안된 값이면 그렇지 않으면 . false
예제
다음 예제에서는 명명ValidateDateAndPrice된 사용자 지정 ValidationRule 을 만듭니다. 메서드에서 Validate 예제에서는 메서드와 Items 속성을 사용하여 TryGetValue 사용자가 양식에 입력한 값을 가져옵니다. 그런 다음, 항목이 100달러를 초과하면 최소 7일 동안 사용할 수 있는지 확인합니다. 이 예제는 클래스에서 더 큰 예제의 BindingGroup 일부입니다.
public class ValidateDateAndPrice : ValidationRule
{
// Ensure that an item over $100 is available for at least 7 days.
public override ValidationResult Validate(object value, CultureInfo cultureInfo)
{
BindingGroup bg = value as BindingGroup;
// Get the source object.
PurchaseItem item = bg.Items[0] as PurchaseItem;
object doubleValue;
object dateTimeValue;
// Get the proposed values for Price and OfferExpires.
bool priceResult = bg.TryGetValue(item, "Price", out doubleValue);
bool dateResult = bg.TryGetValue(item, "OfferExpires", out dateTimeValue);
if (!priceResult || !dateResult)
{
return new ValidationResult(false, "Properties not found");
}
double price = (double)doubleValue;
DateTime offerExpires = (DateTime)dateTimeValue;
// Check that an item over $100 is available for at least 7 days.
if (price > 100)
{
if (offerExpires < DateTime.Today + new TimeSpan(7, 0, 0, 0))
{
return new ValidationResult(false, "Items over $100 must be available for at least 7 days.");
}
}
return ValidationResult.ValidResult;
}
}
Public Class ValidateDateAndPrice
Inherits ValidationRule
' Ensure that an item over $100 is available for at least 7 days.
Public Overrides Function Validate(ByVal value As Object, ByVal cultureInfo As CultureInfo) As ValidationResult
Dim bg As BindingGroup = TryCast(value, BindingGroup)
' Get the source object.
Dim item As PurchaseItem = TryCast(bg.Items(0), PurchaseItem)
Dim doubleValue As Object = Nothing
Dim dateTimeValue As Object = Nothing
' Get the proposed values for Price and OfferExpires.
Dim priceResult As Boolean = bg.TryGetValue(item, "Price", doubleValue)
Dim dateResult As Boolean = bg.TryGetValue(item, "OfferExpires", dateTimeValue)
If (Not priceResult) OrElse (Not dateResult) Then
Return New ValidationResult(False, "Properties not found")
End If
Dim price As Double = CDbl(doubleValue)
Dim offerExpires As Date = CDate(dateTimeValue)
' Check that an item over $100 is available for at least 7 days.
If price > 100 Then
If offerExpires < Date.Today + New TimeSpan(7, 0, 0, 0) Then
Return New ValidationResult(False, "Items over $100 must be available for at least 7 days.")
End If
End If
Return ValidationResult.ValidResult
End Function
End Class
설명
TryGetValue 는 지정된 항목 및 속성에 대한 바인딩이 없거나 변환 오류 또는 이전 유효성 검사 규칙이 실패하여 지정된 속성의 값을 사용할 수 없는 경우 반환 false 합니다.
메서드에서 이 메서드를 ValidationRule.Validate 사용하여 원본에 커밋할 값을 가져옵니다. 형식 value 은 발생하는 단계에 ValidationRule 따라 달라집니다. 예를 들어 a TextBox 가 정수 형식의 속성에 value 바인딩된 데이터인 경우 해당 호출에 해당 집합 TryGetValueValidationStepRawProposedValue이 있는 경우 ValidationRule 문자열입니다. 집합ConvertedProposedValue이 ValidationRuleValidationStep 있는 경우 형식은 바인딩의 value 변환기에서 반환되는 형식입니다. 이 예제에서는 value 일반적으로 정수입니다.