微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Silverlight实战示例5兼集合属性的妙用--客户端模型层(M)

1)服务代理层

      这里的代码都是系统自动产生的,主要负责代理服务端得方法执行,没什么特别可说的.

2)客户端模型层DynamicDataSource.cs

using System;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Ink;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using RIAServices.Web;
using MEntities;
using System.ServiceModel.domainservices.Client;
namespace MAppStructure.Datasource
{
    /// <summary>
    /// 规范化自己的调用参数,目的是将InvokeOperation调用参数转换为
    /// 自己易于处理的参数形式
    /// </summary>
    /// <typeparam name="T"></typeparam>
    public class InvokeEventArgs<T>
    {
        public T Value { get; set; }
        public string ErrorMsg { get; set; }
        public object UserState { get; set; }
        public bool HasError { get; set; }
    }
    /// <summary>
    /// 负责与服务代理层通信,负责调用代理层方法,并将参数转换为客户
    /// 端易于理解和处理的形式
    /// </summary>
    public class DynamicDataSource
    {
        public void GetDynamicDataTable(string strsql,Action<InvokeEventArgs<DynamicDataTable>> CallBack,object UserState)
        {
            DynamicDataContext theContext = new DynamicDataContext();
            theContext.GetDynamicTable(strsql,op => {
                CallBack(CreateEventArgs<DynamicDataTable>(op));
            },UserState);
        }
        //这个函数的目的可以将服务调用错误集中在此进行处理,或者将错误信息转换成客户端比较容易处理的形式。
        private static InvokeEventArgs<T> CreateEventArgs<T>(InvokeOperation<T> InvokeOp)
        {
            InvokeEventArgs<T> theArgs = new InvokeEventArgs<T>();

            if (InvokeOp.HasError == true)
            {
                //将错误标志为已处理.
                InvokeOp.MarkErrorAsHandled();
                theArgs.HasError = true;
                //这里的提示方式可以根据自己的需要进行处理
                theArgs.ErrorMsg = InvokeOp.Error.InnerException.Message;
            }
            else
            {
                theArgs.HasError = false;
                theArgs.Value = InvokeOp.Value;
            }
            theArgs.UserState = InvokeOp.UserState;
            return theArgs;
        }
    }
}

这一层的目的就是进行数据及服务的预处理,客户端得缓存也需放在这一层。因为VM层是针对V的,一般情况下很难共用,而M层中的很多服务都可以出现在不同的VM 中,这也是为什么要单独在服务代理层上再加一层的原因,而且这一层可以建立基类,便于控制和扩展。服务代理层是没办法做基类的,因为代码都是动态生成的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐