专栏首页walterlv - 吕毅的博客如何组织一个同时面向 UWP/WPF/.Net Core 控制台的 C# 项目解决方案

如何组织一个同时面向 UWP/WPF/.Net Core 控制台的 C# 项目解决方案

如何组织一个同时面向 UWP/WPF/.Net Core 控制台的 C# 项目解决方案

2017-10-21 03:20

希望写一个小型工具,给自己和需要的人。考虑到代码尽可能的复用,我准备采用 .Net Standard 来编写大多数核心代码,并基于 .Net Core 编写跨平台控制台入口,用 WPF 编写桌面端 UI 入口,用 UWP 作为可上架商店的 UI 入口,然后用 Shared Project 共享 WPF 和 UI 的多数 UI 入口代码。

阅读本文将了解到如何在尽可能复用代码的情况下组织这样的 C# 解决方案。


工具型项目,选择了控制台

用 WPF 开发桌面 UI,因为其有强大的 .NET Framework 库在背后支持,外加方便而功能齐全的 XAML 开发环境,在用 C# 进行桌面应用程序开发的时候不失为一种优秀的选择。但微软却并不怎么重视 WPF,而一直投入较大资源在半死不活的 UWP 上,导致 WPF 现在有非常多的坑是在 UWP 上才解的。然而,微软却并没有好好运营 UWP,以至于其开发者急剧减少,再在上面投入太多精力投入产出比显得太低。

.NET Framework 是个优秀的框架,可是与 Windows 桌面端绑得太死,以至于在当下多平台发展得都不错的情况下失去了大多数的竞争力。但是 .NET Core 解决了这个问题。然而谈到 UI 的跨平台,就是一个巨大的投入和难以见底的坑,以至于基于 .NET Core 且跨平台的 UI 框架目前依然没有出现。

毕竟只是工具型项目,并不想去动用大型 UI 框架 Xamarin/Unity,以至于写一个 .NET Core 控制台程序成了小型工具型项目的最佳解决方案了。

工具型项目是任务导向的,能完成任务为最终目的。控制台与配置文件的配合不仅足以完成任务,还为自动化或其他工具集成提供了方便。这里提供 UI 只是为了方便此工具用户的初学使用和理解。

组织一个 C# 解决方案

我们总共涉及到的 Visual Studio 项目类型有这五个:

  • 类库(.NET Standard)
  • 共享项目
  • 控制台应用(.NET Core)
  • WPF 应用(.NET Framework)
  • 空白应用(通用 Windows)

.NET Standard 和共享项目是默认就装上的,但其他三个却不是。需要在 Visual Studio 安装界面中额外勾选:

  • 用于安装通用 Windows 项目,如果你对此不感兴趣,忽略即可
  • 用于安装 WPF 应用,如果你对此不感兴趣,忽略即可
  • 用于安装 .NET Core 项目,这是跨平台的重点,建议安装

在 Visual Studio 中创建一个解决方案的时候依次添加这五种项目。

  • 我们的主要逻辑代码全在 .NET Standard 项目中。这里包含了完整的功能实现,可以脱离其他四种实现完整功能。
  • .NET Core 控制台项目仅仅作为入口,引用 .NET Standard 的项目,将用户输入的命令转为具体的函数调用。
  • 共享项目的代码主要是 UI 或 UI 辅助代码,例如控制 UI 的逻辑和 ViewModel。
  • UWP 和 WPF 项目仅包含 UI(XAML)和必要的不一致的 UI 控制逻辑,通过链接的方式将共享项目中的代码引入如何链接?
  • 其他的工具库当然也是需要的,但为了通用,建议优先选择 .NET Standard 的库。

这样,项目在 Visual Studio 中看起来大概是这样的:

本文会经常更新,请阅读原文: https://walterlv.com/post/organize-csharp-project-targeting-multiple-platforms.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系 (walter.lv@qq.com)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • LTS(Long-term Support)是怎样的一种支持方式

    2018-07-04 13:29

    walterlv
  • 当我们使用 MVVM 模式时,我们究竟在每一层里做些什么?

    2017-11-29 17:29

    walterlv
  • .NET 三个字母究竟应该如何大小写?前面的 “.” 什么时候能够去掉?(.NET Standard / dotnet-core / net472)

    发布于 2018-05-28 08:23 更新于 2018-07...

    walterlv
  • 【PHP】Propel的使用,看这一篇就够了

    本文为学习Propel框架使用的笔记,默认已经安装好Propel环境,若有读者不知如何安装Propel,可参考《听说你PHP配置Composer遇到了一些困境》...

    代码咖啡
  • 使用代码创建BRF ruleset

    Jerry Wang
  • Thinking--函数强制参数

    JavaScript 是弱类型语言,对于函数的参数不会做强制限制,如果需要限制,我们如何处理?

    奋飛
  • 逻辑回归和深度神经网络:哪个更适合你?

    【导读】简单的逻辑回归于复杂的深度神经网络都广泛应用于各种分类场景,但是针对不同的任务到底哪种模型更适合呢?本文从参数量和特定数据的使用两方面来阐述两种模型的区...

    WZEARW
  • 敏捷项目管理【海史密斯版】(一)

    一、敏捷革命 1.当我们将试验成本减少到足够低时,整个产品开发的经济学就会发生改变——从以预测为基础的流程(定义、设计,然后建造)转变为一个以适应为基础的流程(...

    硬核项目经理
  • 撮合引擎开发:流程的代码实现

    我们要开始聊代码实现逻辑了,如果不记得之前讲的目录结构,请回去翻看前文。聊代码实现的第一步自然从程序入口开始,核心就两个函数:init() 和 main(),其...

    Keegan小钢
  • 波形图(人人网2017春招真题)

    小明正在做物理实验,他在示波器上观察波形。在每一时刻,他能观察到两种可能的波形,一种是水平波形,由两个下划线组成:”__”。一种是脉冲波形,由一个斜杠和一个反斜...

    AI那点小事

扫码关注云+社区

领取腾讯云代金券