在混合开发框架模式中,有时候我们在处理树形节点的时候,需要很多关联的处理,可能需要结合用户配置信息,属性字典,以及表的字段分类等信息来展示一个结构树,那么在处理的时候就可能会频繁的对这些接口API进行调用,而如果我们使用Web API一次性的获取树形节点信息,然后统一加载的话,性能会提升很多,本篇随笔介绍通过封装一个总的树形结构列表数据返回的Web API,从而在Winform客户端一次性展示的方式,实现性能的优化处理。

1、树形结构展示效果

如下面的CRM客户关系管理系统中,我们需要展示很多客户相关的树形节点,以方便快捷查询相关类型的客户信息。

那么这个树列表就需要结合很多属性来处理了,包括了客户的字段信息,客户配置显示信息,每个字段类型的对应的字典信息,如客户状态、客户类型等等。

因此如果在客户端整合逻辑,那么需要对几个不同的处理接口进行调用并处理,这种解析起来比较慢,而且也会导致处理效率问题。

一般情况下,我们云端的服务器性能会比客户端的性能更好一些,这些对数据库处理的逻辑封装在Web API的后盾会更加方便,也就是瘦客户端的方式更有效率了。

2、Web API端封装处理逻辑

例如我们定义一个以下的接口来获取数据。

        /// <summary>
/// 获取客户树形类别的数据
/// </summary>
/// <param name="userId">当前用户ID</param>
/// <param name="companyId">所属公司ID</param>
/// <param name="dataFilter">数据过滤条件</param>
/// <param name="shareUserCondition">分配用户ID条件</param>
/// <returns></returns>
List<TreeNodeInfo> GetCustomerTree(string userId, string companyId, string dataFilter, string shareUserCondition);

其中TreeNodeInfo对象是我们自己定义的一个对象,用来承载具有层级信息的列表信息。

具体这个类的代码如下所示。

    /// <summary>
/// 用来承载TreeNode的信息
/// </summary>
[Serializable]
[DataContract]
public class TreeNodeInfo
{
/// <summary>
/// 子对象集合
/// </summary>
[DataMember]
public List<TreeNodeInfo> Nodes { get; set; } /// <summary>
/// 节点名称
/// </summary>
[DataMember]
public string Text { get; set; } /// <summary>
/// 节点标签
/// </summary>
[DataMember]
public string Tag { get; set; } /// <summary>
/// 图标序号
/// </summary>
[DataMember]
public int IconIndex { get; set; } /// <summary>
/// 是否展开
/// </summary>
[DataMember]
public bool IsExpanded { get; set; } /// <summary>
/// 前景色
/// </summary>
[DataMember]
public string ForeColor { get; set; } /// <summary>
/// 默认构造函数
/// </summary>
public TreeNodeInfo() {
this.Nodes = new List<TreeNodeInfo>();
} /// <summary>
/// 参数构造函数
/// </summary>
/// <param name="text">节点名称</param>
/// <param name="iconIndex">图标序号</param>
/// <param name="tag">节点标签</param>
public TreeNodeInfo(string text, int iconIndex, string tag = "") : this()
{
this.Text = text;
this.IconIndex = iconIndex;
this.Tag = tag;
}
}

Web API端的控制器方法如下所示。

最后具体在客户端界面绑定显示数据的逻辑如下所示。

        /// <summary>
/// 使用Json对象创建列表树
/// </summary>
private void InitTree()
{
//清空节点信息
this.treeView1.Nodes.Clear(); //通过Web API方式获取树对象列表结构
var list = CallerFactory<ICustomerService>.Instance.GetCustomerTree(LoginUserInfo.ID, this.SelectedCompanyID,
this.DataFilterCondition, this.ShareUserCondition); if (list != null && list.Count > )
{
//遍历每个节点,生成对应的TreeView对象节点
foreach (var node in list)
{
//构建TreeView对象节点信息
TreeNode parentNode = new TreeNode(node.Text, node.IconIndex, node.IconIndex);
parentNode.Tag = node.Tag;
if (!string.IsNullOrEmpty(node.ForeColor))
{
//如果节点颜色有值,则修改前景色
parentNode.ForeColor = ColorTranslator.FromHtml(node.ForeColor);
} //递归处理树形列表
InitTreeNode(node.Nodes, parentNode);
if (parentNode.Text != "标记颜色")
{
parentNode.Expand();//选择性的展开部分一级节点
} //把根节点加入到树对象里面显示
this.treeView1.Nodes.Add(parentNode);
}
}
} /// <summary>
/// 递归处理树形列表
/// </summary>
/// <param name="nodes">树节点信息对象</param>
/// <param name="pNode">TreeView根节点</param>
private void InitTreeNode(List<TreeNodeInfo> nodes, TreeNode pNode)
{
foreach (TreeNodeInfo node in nodes)
{
TreeNode subNode = new TreeNode(node.Text, node.IconIndex, node.IconIndex);
subNode.Tag = node.Tag;
if (!string.IsNullOrEmpty(node.ForeColor))
{
//如果节点颜色有值,则修改前景色
subNode.ForeColor = ColorTranslator.FromHtml(node.ForeColor);
} //递归调用
InitTreeNode(node.Nodes, subNode);
pNode.Nodes.Add(subNode);
}
}

这里基本不会涉及很多逻辑,我们只需要对树形节点的结构进行遍历展示即可。

其实后端已经给我们处理好很多数据了,包括对节点构建、数据字典的处理,以及每个条件的数量处理都合并一起,它的逻辑还是很多的。

这个部分的逻辑由于代码量比较大,我们可以简化抽取出来一个辅助类处理,这样在需要的地方直接调用辅助类进行处理就可以了。

抽取辅助类后,对处理逻辑的调用简单了很多。

 CustomerHelper helper = new CustomerHelper();
var result = helper.GetCustomerTree(userId, companyId, dataFilter, shareUserCondition);

这部分有300多行代码,具体就不再一一介绍了,主要就是对各个接口的处理,获取数据并组装起来。

这种在服务器端对主要逻辑进行封装,简化客户端的处理逻辑,是我们推荐的方式,可以极大的提高界面响应效率,减少不必要的网络延迟损耗,从而提高用户的体验效果,对于具有较高运算速度的服务器,更是物尽其用。

在混合开发框架模式中,简化客户端对Web API的频繁调用的更多相关文章

  1. Identity Server 4 从入门到落地(十)—— 编写可配置的客户端和Web Api

    前面的部分: Identity Server 4 从入门到落地(一)-- 从IdentityServer4.Admin开始 Identity Server 4 从入门到落地(二)-- 理解授权码模式 ...

  2. [水煮 ASP.NET Web API2 方法论](1-1)在MVC 应用程序中添加 ASP.NET Web API

    问题 怎么样将 Asp.Net Web Api 加入到现有的 Asp.Net MVC 项目中 解决方案 在 Visual Studio 2012 中就已经把 Asp.Net Web Api 自动地整合 ...

  3. [水煮 ASP.NET Web API2 方法论](1-2)在 WebForm 应用程序中添加 ASP.NET Web API

    问题 怎么样将 Asp.Net Web Api 加入到 Asp.Net Web From 应用程序中 解决方案 在 Visual Studio 2013 中,创建新的 Web From,可以直接在&q ...

  4. 尝新体验ASP.NET Core 6预览版本中发布的最小Web API(minimal APIS)新特性

    本文首发于<尝新体验ASP.NET Core 6预览版本中发布的最小Web API(minimal APIS)新特性> 概述 .NET开发者们大家好,我是Rector. 几天前(美国时间2 ...

  5. 【Azure API 管理】在APIM中使用客户端证书验证API的请求,但是一直提示错误"No client certificate received."

    API 管理 (APIM) 是一种为现有后端服务创建一致且现代化的 API 网关的方法. 问题描述 在设置了APIM客户端证书,用户保护后端API,让请求更安全. 但是,最近发现使用客户端证书的API ...

  6. Self Host模式下的ASP. NET Web API是如何进行请求的监听与处理的?

    构成ASP.NET Web API核心框架的消息处理管道既不关心请求消息来源于何处,也不需要考虑响应消息归于何方.当我们采用Web Host模式将一个ASP.NET应用作为目标Web API的宿主时, ...

  7. 简单记录在Visual Studio 2013中创建ASP.NET Web API 2

    在很多跨平台的应用中就需要Web API ,比如android与数据库的交互. Create a Web API Project 选择新建项目下的模板下的Visual C#节点下的Web节点,在模板列 ...

  8. 在Docker容器中运行.Net Core web Api项目

    安装Docker环境 参考本人这篇<CentOS 7 下Docker的安装>文章进行安装以及环境配置,这里不做赘述. 通过.NetCore开发WebApi项目 1. 创建.Net Core ...

  9. ABP开发框架前后端开发系列---(5)Web API调用类在Winform项目中的使用

    在前面几篇随笔介绍了我对ABP框架的改造,包括对ABP总体的介绍,以及对各个业务分层的简化,Web API 客户端封装层的设计,使得我们基于ABP框架的整体方案越来越清晰化, 也越来越接近实际的项目开 ...

随机推荐

  1. PMBook - 上课体会

    一.上课感觉怎么样? 这两天都在培训PMP,第一天提前20分到的,空位很多,挑了第二排坐下,看投影效果挺好.第二天我提前30分钟到教室,中间的位置都坐满了,只能找其他位置了.看来大家积极性提高了很多, ...

  2. ASP.NET Core 3.0 上的gRPC服务模板初体验(多图)

    早就听说ASP.NET Core 3.0中引入了gRPC的服务模板,正好趁着家里电脑刚做了新系统,然后装了VS2019的功夫来体验一把.同时记录体验的过程.如果你也想按照本文的步骤体验的话,那你得先安 ...

  3. 前端笔记之JavaScript面向对象(三)初识ES6&underscore.js&EChart.js&设计模式&贪吃蛇开发

    一.ES6语法 ES6中对数组新增了几个函数:map().filter().reduce() ES5新增的forEach(). 都是一些语法糖. 1.1 forEach()遍历数组 forEach() ...

  4. 用命令行撤销工作区的所有更改(修改文件&&新增文件)

    话说起来之前放弃工作区所有的更改,我一直都是直接用VSCode在workingTree的按钮,如下:   直到有一天我感觉这样不够酷,于是我试了git reset --hard. 然并卵,这个命令虽然 ...

  5. 卷积神经网络 CNN 学习笔记

    激活函数Relu 最近几年卷积神经网络中,激活函数往往不选择sigmoid或tanh函数,而是选择relu函数.Relu函数的定义 $$f(x)= max(0,x)$$ Relu函数图像如下图所示: ...

  6. [个人网站搭建]·Django增加评论功能(Python3)

    [个人网站搭建]·Django增加评论功能 个人主页--> https://xiaosongshine.github.io/ 个人网站搭建github地址:https://github.com/ ...

  7. SmartSql Config配置

    Demo <?xml version="1.0" encoding="utf-8" ?> <SmartSqlMapConfig xmlns=& ...

  8. Docker进阶之八:搭建LNMP网站平台实战

    搭建LNMP网站平台实战 LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写.L指Linux,N指Nginx,M一般指MySQL,也可以指MariaDB,P一般指PHP,也可 ...

  9. #6 判断一个数是否为2的n次方

    「ALBB面试题」 [题目] 如何判断一个数是否为2的n次方 [题目分析] 看到这种题,相信大家第一反应就是循环除2,这样做肯定是可以得出结果的:但是这种做法无疑大大增加了计算机的运行时间,一个非常大 ...

  10. Spring Cloud项目之断路器集群监控Hystrix Dashboard

    微服务(Microservices Architecture)是一种架构风格,一个大型复杂软件应用由一个或多个微服务组成.系统中的各个微服务可被独立部署,各个微服务之间是松耦合的.每个微服务仅关注于完 ...