用Microsoft.Extensions.Hosting 管理WPF项目.

2024-06-24 14:04

本文主要是介绍用Microsoft.Extensions.Hosting 管理WPF项目.,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先引入必要的包:

	<ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog" Version="4.0.0" /><PackageReference Include="Serilog.Extensions.Logging" Version="8.0.0" /><PackageReference Include="Serilog.Sinks.Console" Version="6.0.0" /><PackageReference Include="Serilog.Sinks.File" Version="6.0.0" /></ItemGroup>

将app.xaml 的属性-生成操作改为"页"

在这里插入图片描述
此时弹出:

在这里插入图片描述

点击"取消"

点击显示所有文件, 将app.xaml包含在项目中

在这里插入图片描述

此时, 在csproj中,

  <ItemGroup><ApplicationDefinition Remove="App.xaml" /></ItemGroup><ItemGroup><Page Include="App.xaml" /></ItemGroup>

在app.xaml.cs中 写入

    public partial class App : Application{[STAThread]static  void Main(string[] args){var app = new App();app.InitializeComponent();app.Run();}}

点击运行, 此时项目已经可以运行起来了
在这里插入图片描述

在app.xaml中 删除

             StartupUri="MainWindow.xaml"

改为

<Application x:Class="HoistWpfTest.App"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="clr-namespace:HoistWpfTest"><Application.Resources></Application.Resources>
</Application>
        [STAThread]static void Main(string[] args){using var host = CreateHostBuilder(args).Build();host.Start();var app = new App();app.InitializeComponent();app.MainWindow = host.Services.GetRequiredService<MainWindow>();//app.MainWindow.Show();app.MainWindow.Visibility = Visibility.Visible;app.Run();}private static IHostBuilder CreateHostBuilder(string[] args){return Host.CreateDefaultBuilder(args).ConfigureServices(services =>{services.AddSingleton<MainWindow>();});}

此时 已经用Host管理了wpf项目.

较为完整的配置:

    public partial class App : Application{[STAThread]static async void Main(string[] args){using var host = CreateHostBuilder(args).Build();await host.StartAsync();var app = new App();app.InitializeComponent();app.MainWindow = host.Services.GetRequiredService<MainView>();//app.MainWindow.Show();app.MainWindow.Visibility = Visibility.Visible;app.Run();}private static IHostBuilder CreateHostBuilder(string[] args){return Host.CreateDefaultBuilder(args).ConfigureServices(services =>{services.AddSingleton<MainViewModel>();services.AddSingleton(sp => new MainView{DataContext = sp.GetRequiredService<MainViewModel>()});services.AddSingleton<WeakReferenceMessenger>();services.AddSingleton<IMessenger, WeakReferenceMessenger>(sp =>sp.GetRequiredService<WeakReferenceMessenger>());services.AddSingleton(_ => Current.Dispatcher);}).ConfigureLogging(logging =>{logging.ClearProviders();Log.Logger = new LoggerConfiguration()//.WriteTo.Console().WriteTo.File("log.txt", rollingInterval: RollingInterval.Day).CreateLogger();logging.AddSerilog(Log.Logger);});}}

这篇关于用Microsoft.Extensions.Hosting 管理WPF项目.的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1090358

相关文章

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

关于如何更好管理好数据库的一点思考

本文尝试从数据库设计理论、ER图简介、性能优化、避免过度设计及权限管理方面进行思考阐述。 一、数据库范式 以下通过详细的示例说明数据库范式的概念,将逐步规范化一个例子,逐级说明每个范式的要求和变换过程。 示例:学生课程登记系统 初始表格如下: 学生ID学生姓名课程ID课程名称教师教师办公室1张三101数学王老师101室2李四102英语李老师102室3王五101数学王老师101室4赵六103物理陈

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

springboot家政服务管理平台 LW +PPT+源码+讲解

3系统的可行性研究及需求分析 3.1可行性研究 3.1.1技术可行性分析 经过大学四年的学习,已经掌握了JAVA、Mysql数据库等方面的编程技巧和方法,对于这些技术该有的软硬件配置也是齐全的,能够满足开发的需要。 本家政服务管理平台采用的是Mysql作为数据库,可以绝对地保证用户数据的安全;可以与Mysql数据库进行无缝连接。 所以,家政服务管理平台在技术上是可以实施的。 3.1

vue3项目将所有访问后端springboot的接口统一管理带跨域

vue3项目将所有访问后端springboot的接口统一管理带跨域 一、前言1.安装Axios2.创建Axios实例3.创建API服务文件4.在组件中使用API服务 二、跨域三、总结 一、前言 在Vue 3项目中,统一管理所有访问后端Spring Boot接口的最佳实践是创建一个专门的API服务层。这可以让你的代码更加模块化、可维护和集中管理。你可以使用Axios库作为HTT

vscode-创建vue3项目-修改暗黑主题-常见错误-element插件标签-用法涉及问题

文章目录 1.vscode创建运行编译vue3项目2.添加项目资源3.添加element-plus元素4.修改为暗黑主题4.1.在main.js主文件中引入暗黑样式4.2.添加自定义样式文件4.3.html页面html标签添加样式 5.常见错误5.1.未使用变量5.2.关闭typescript检查5.3.调试器支持5.4.允许未到达代码和未定义代码 6.element常用标签6.1.下拉列表

局域网内vue2 配置本地IP地址访问项目

在日常开发中同事可能需要访问你的前端项目,可以通过配置实现通过ip访问 一.首先找到config文件夹目录下的 index.js文件             将此处的host的值修改为0.0.0.0(即 host: 0.0.0.0) // Various Dev Server settings//host: 'localhost' //将localhost进行替换成 0.0.0.0host:

把Tiled中做出的地图弄到项目中~~就是懒,为了以后直接复制写过来

1.现在.h中声明private: cocos2d::CCSprite* ninja; cocos2d::CCTMXTiledMap*  tileMap; 然后.cpp中加入tileMap = CCTMXTiledMap::create("MyTileMap.tmx"); CCTMXLayer* backLayer = tileMap->layerNamed("Tile L

CocoStudio中的UI弄到项目中

1、   与alpah版相比,beta版中更改了创建的脚本,可以自定义项目的目录,接下来我们看看。先上图: 2、项目创建     找到 cocos2dx根目录/tools/project-creator/create_project.py文件,双击运行即可。如果未安装python环境,则需要下载安装。脚本运行起来,会显示一个图形界面,用以设置相应的项目