silverlight   发布时间:2022-05-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了学习silverLIght大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

概述

现在开始学习silverlight.so I decide to regord my gain 1. 在xaml中,把一个倥件的属性的值,赋值另一个属性。   SELEctedDate="{Binding ElementName=dpPaidDate, Path=DisplayDatE} 如上,是通过bing来实现的,这样SELEctDate属性的值,就和属性DispalyDate的值是一样的。

现在开始学习silverlight.so I decide to regord my gain

1. 在xaml中,把一个倥件的属性的值,赋值另一个属性

 

SELEctedDate="{Binding ElementName=dpPaidDate,Path=DisplayDatE}

如上,是通过bing来实现的,这样SELEctDate属性的值,就和属性DispalyDate的值是一样的。

由于对于DatePicker来说,DisplayDate的值初始化是当天,这样,当界面显示时,认的日期就是当天。

 

2.关于UI,数据绑定的后,验证界面输入的问题。

场景:

                   如果将一个值类型字段绑定到一个元素上并开启数据验证功能,并为这个字段加上不能为空的验证。

        正常情况下清空输入应该返回输入不能为空的提示,但是实际情况是无论怎样操作,一旦对值类型的字段做清空操作得到的验证提示都是 

“input String was not a correct format.”(silverlight4不存在该bug)

 

异常原因:

         在绑定字段更新的时候,任何从ui输入更新到目标数据源异常认情况下是被sl内部吃掉的,但是一旦开启了数据验证就会被验证控件捕获。

这里的提示就是空值转换成数据源中的值类型时导致的异常。

 

解决方案:

    通过上面的猜想,之前认为把数据源的这个值类型改为可空类型就可以了,但是尝试了一下还是报同样的提示。然后给这个字段加上了个自定的convert类,

观察其在ConverBACk时,得到的value,发现原来在清空操作的时,返回的value结构是String.Empty而不是null,这里需要手动的将String.Empty转换为null,在赋值给可空类型才能正常转换。

 

 代码如下:

    Model:

      

 [Validation(typeof(LessOrequalThanFulfillTransitQtyValidator))]
        [Validation(ValidatorTypes.Interger)]
        [Validation(ValidatorTypes.required)]
        public new int? Quantity       //在silverlight3 下对值类型做不能为空的验证时,一定要将字段定义为可空类型
        {
            get
            {
                return base.Quantity;
            }
 
            set
            {
                base.Quantity = value;
            }
    }

 

ValueConverter:

  

  public class NullAbledIntToIntConvernt : IValueConverter
    {
 
        #region IValueConverter Members
 
        public object Convert(object value,Type targetType,object parameter,System.Globalization.CultureInfo culturE)
        {
            if (value == null)
            {
                value = 0;
            }
 
            return value;
        }
 
        public object ConvertBACk(object value,System.Globalization.CultureInfo culturE)
        {
           //保证可空类型的转化正常
            if (value == null || String.IsNullOrEmpty(value.ToString().Trim()))
            {
                value = null;
            }
 
            return value;
        }
 
        #endregion
 }

 

Xaml:

//在xaml为响应的字段加上自定义的converter

  //定义一个转化类的实例

    <UserControl.resources>

        <local:NullAbledIntToIntConvernt x:Key="IntConverter"/>

    </UserControl.resources>

 

  <TextBox     TEXT="{Binding Quantity,Mode=TwoWay,ValidatesOnExceptions=True,NotifyOnValidationError=True,Converter={StaticresourcE intConverter}}" 

                                                 Margin="5 0 0 0" HorizontalAlignment="Left"

                                                 MaxLength="9"

                                                 KeyDown="TextBox_KeyDown"

                                                 Style="{Staticresource ShortTextBoxStylE}"></TextBox>

 

3.扩展验证属性

把下面的代码写到服务端的以.shared.cs结尾命名的文件中,则客户端会自动生成一样的文件,方便使用。

public class decimalValidator : ValidationAttribute
    {
        protected override ValidationResult IsValid(object value,ValidationContext validationContext)
        {
             if ((value != null) && !String.IsNullOrEmpty(value.ToString().Trim()))
            {
                decimal outValue;
                if (!decimal.TryParse(value.ToString(),out outvalue))
                {
                    return new ValidationResult(Errormessage,new String[] { validationContext.MemberName });
                }
                return ValidationResult.success;
            }
             return new ValidationResult(Errormessage,new String[] { validationContext.MemberName });
        }
 
    }

 

这样就可以新建的验证属性attribute

如:    [decimalValidator(Errormessage = "This is not a decimal.")]       

      

  public String Customernumber
        {
            get;
            set;
        }

大佬总结

以上是大佬教程为你收集整理的学习silverLIght全部内容,希望文章能够帮你解决学习silverLIght所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。