2017-06-19 55 views
0

我有一個Xamarin.Form應用程序,我正在使用模型狀態消費一個ASP.Net Web WebAPI以在我的內部模型中進行驗證。如果我得到了一個「錯誤的請求」我的API返回此JSON對象:Xamarin表單驗證和ASP.Net WebAPI

{ 
    message: 'The request is invalid.', 
    modelState: { 
     model.**Name**: [ 
      "The name is empty" 
     ] 
    } 
    } 

所以,我想簡化我的UI工作來讀取結果,我的問題是:我該怎麼做才能使用這個對象在我的UI中顯示錯誤?或者Xamarin表單是否有像ASP.NET MVC Validator @ Html.ValidationMessageFor(model => model.Name)的任何幫助程序,它可以自動顯示UI中的錯誤?

謝謝!

回答

1

您可以創建控件的行爲,如下面的一個

public class EmailValidatorBehavior : Behavior<Entry> 
    { 
     const string emailRegex = @"^(?("")("".+?(?<!\\)""@)|(([0-9a-z]((\.(?!\.))|[-!#\$%&'\*\+/=\?\^`\{\}\|~\w])*)(?<=[0-9a-z])@))" + 
      @"(?(\[)(\[(\d{1,3}\.){3}\d{1,3}\])|(([0-9a-z][-\w]*[0-9a-z]*\.)+[a-z0-9][\-a-z0-9]{0,22}[a-z0-9]))$"; 


     protected override void OnAttachedTo(Entry bindable) 
     { 
      bindable.TextChanged += HandleTextChanged; 
      base.OnAttachedTo(bindable); 
     } 

     void HandleTextChanged(object sender, TextChangedEventArgs e) 
     { 
      bool IsValid = false; 
      IsValid = (Regex.IsMatch(e.NewTextValue, emailRegex, RegexOptions.IgnoreCase, TimeSpan.FromMilliseconds(250))); 
      ((Entry)sender).TextColor = IsValid ? Color.Default : Color.Red; 
     } 

     protected override void OnDetachingFrom(Entry bindable) 
     { 
      bindable.TextChanged -= HandleTextChanged; 
      base.OnDetachingFrom(bindable); 
     } 
    } 

使用此行爲在XAML如下

添加命名空間爲您的行爲

xmlns:local="clr-namespace:Mynamespace.Behaviors" 

添加行爲入門

<Entry x:Name="txtEmail" Placeholder="Enter Your Password" > 
     <Entry.Behaviors> 
     <local:EmailValidatorBehavior /> 
     </Entry.Behaviors> 
    </Entry> 

上述行爲將驗證電子郵件,並在電子郵件無效時更改文本框的顏色。就像你可以創建更多的行爲

+0

你能給我更多關於這方面的信息嗎?那麼XAML呢? –

+0

謝謝你的回答!但我的意思是,我有一個所有型號的PLC,對於每個型號的屬性,我都有一個數據符號用於在我的web api中進行驗證。我怎樣才能在每個模型中使用Xamarin表單中的驗證[見本文](https://msdn.microsoft.com/en-us/library/ee256141(v = vs.98).aspx)? –