当前位置: 首页 > news >正文

【C#生态园】打造现代化跨平台应用:深度解析.NET桌面应用工具

选择最适合你的.NET UI框架:全面解析六种热门选择

前言

在现代软件开发中,选择合适的桌面应用框架和UI库对于开发人员来说至关重要。本文将介绍几种流行的.NET桌面应用框架和UI库,包括Eto.Forms、Avalonia、ReactiveUI、MahApps.Metro、MaterialDesignInXAML和Uno Platform。通过对每种工具的核心功能、使用场景、安装与配置以及API概览进行全面介绍,读者将能够更好地了解其特性和适用情况,从而为自己的项目选择合适的工具提供参考。

欢迎订阅专栏:C#生态园

文章目录

  • 选择最适合你的.NET UI框架:全面解析六种热门选择
    • 前言
    • 1. Eto.Forms:一个跨平台的桌面应用框架
      • 1.1 简介
        • 1.1.1 核心功能
        • 1.1.2 使用场景
      • 1.2 安装与配置
        • 1.2.1 安装指南
        • 1.2.2 基本配置
      • 1.3 API 概览
        • 1.3.1 控件创建
        • 1.3.2 事件处理
    • 2. Avalonia:一个跨平台的.NET UI框架
      • 2.1 简介
        • 2.1.1 核心功能
        • 2.1.2 使用场景
      • 2.2 安装与配置
        • 2.2.1 安装方法
        • 2.2.2 基本设置
      • 2.3 API 概览
        • 2.3.1 XAML布局
        • 2.3.2 数据绑定
    • 3. ReactiveUI:一个响应式编程库
      • 3.1 简介
        • 3.1.1 核心功能
        • 3.1.2 使用场景
      • 3.2 安装与配置
        • 3.2.1 安装指南
        • 3.2.2 基本设置
      • 3.3 API 概览
        • 3.3.1 响应式属性
        • 3.3.2 命令绑定
    • 4. MahApps.Metro:一个现代化风格的WPF UI库
      • 4.1 简介
        • 4.1.1 核心功能
        • 4.1.2 使用场景
      • 4.2 安装与配置
        • 4.2.1 安装指导
        • 4.2.2 基本配置
      • 4.3 API 概览
        • 4.3.1 样式定义
        • 4.3.2 控件模板
    • 5. MaterialDesignInXAML:一个Material Design风格的XAML库
      • 5.1 简介
        • 5.1.1 核心功能
        • 5.1.2 使用场景
      • 5.2 安装与配置
        • 5.2.1 安装指南
        • 5.2.2 基本设置
      • 5.3 API 概览
        • 5.3.1 主题设置
        • 5.3.2 控件使用
    • 6. Uno Platform:一个支持跨平台的XAML和C#解决方案
      • 6.1 简介
        • 6.1.1 核心功能
        • 6.1.2 使用场景
      • 6.2 安装与配置
        • 6.2.1 安装指南
        • 6.2.2 基本设置
      • 6.3 API 概览
        • 6.3.1 XAML布局
        • 6.3.2 数据绑定
    • 总结

1. Eto.Forms:一个跨平台的桌面应用框架

Eto.Forms 是一个开源的 .NET 跨平台桌面应用程序框架,可以用于创建跨平台的用户界面。它能够在不同的操作系统上使用本地的用户界面组件,同时提供了简洁、易懂的 API,使得开发者可以轻松地编写可跨平台运行的桌面应用程序。

1.1 简介

1.1.1 核心功能

Eto.Forms 提供了一套统一的 API,用于创建并管理跨平台的用户界面,包括窗体、按钮、文本框、下拉框等各种常见控件。它还支持事件处理、布局管理等功能,让开发者可以专注于应用程序的业务逻辑,而不必过多关注不同平台下的界面实现细节。

1.1.2 使用场景

Eto.Forms 适用于需要同时在 Windows、Mac 和 Linux 等多个操作系统上运行的桌面应用程序。无论是企业应用、工具软件还是个人项目,都可以使用 Eto.Forms 来构建跨平台的用户界面。

1.2 安装与配置

1.2.1 安装指南

通过 NuGet 可以很方便地安装 Eto.Forms。在 Visual Studio 中,打开 NuGet 包管理器控制台,执行以下命令即可安装:

Install-Package Eto.Forms

更多安装方式和更新日志可以参考Eto.Forms 官方网站。

1.2.2 基本配置

在开始使用 Eto.Forms 之前,需要确保已经正确配置了 .NET 开发环境,并且理解了不同平台上的 UI 差异。另外,还需要引入 Eto.Forms 名称空间:

using Eto.Forms;

1.3 API 概览

1.3.1 控件创建

以下是一个简单的示例,演示了如何创建一个窗体并添加一个按钮控件:

using Eto.Forms;public class MyForm : Form
{public MyForm(){Title = "Hello, Eto.Forms!";var button = new Button { Text = "Click me!" };button.Click += (sender, e) => MessageBox.Show("Button Clicked!");Content = button;}
}

在这个示例中,我们创建了一个名为 MyForm 的窗体,并在窗体中添加了一个按钮控件。当按钮被点击时,会弹出一个消息框显示 “Button Clicked!”。

1.3.2 事件处理

Eto.Forms 支持事件处理机制,可以方便地响应用户交互。例如,为按钮的点击事件添加处理方法:

button.Click += (sender, e) => MessageBox.Show("Button Clicked!");

点击按钮时,会弹出一个消息框显示 “Button Clicked!”。

更详细的 API 说明和示例可以参考Eto.Forms 文档。

2. Avalonia:一个跨平台的.NET UI框架

2.1 简介

Avalonia是一个跨平台的开源.NET UI框架,可用于构建现代桌面应用程序。它的设计灵感来自于WPF和Silverlight,旨在提供高性能、可扩展、可定制的用户界面。Avalonia支持XAML布局和数据绑定,使开发者能够快速构建功能丰富、美观的跨平台桌面应用。

2.1.1 核心功能
  • 跨平台支持:Avalonia可以在Windows、Linux和macOS上运行,为开发者提供了更大的目标受众。
  • XAML布局:借助XAML语言,开发者可以轻松创建复杂的用户界面布局。
  • 数据绑定:Avalonia支持强大的数据绑定机制,使UI与数据模型之间的交互变得更加便捷。
2.1.2 使用场景

Avalonia适用于需要构建跨平台桌面应用的开发者,尤其是那些熟悉或已经使用过XAML和.NET技术栈的开发团队。

2.2 安装与配置

2.2.1 安装方法

开发者可以通过NuGet包管理器将Avalonia集成到他们的.NET项目中。具体的安装步骤可以参考Avalonia官方文档。

2.2.2 基本设置

在项目中引用Avalonia库后,通常需要创建一个 AppBuilder 对象并调用 UsePlatformDetect() 方法来启用Avalonia的跨平台支持。以下是一个基本的配置示例:

using Avalonia;
using Avalonia.Controls.ApplicationLifetimes;class Program
{static void Main(string[] args){BuildAvaloniaApp().StartWithClassicDesktopLifetime(args);}public static AppBuilder BuildAvaloniaApp(){return AppBuilder.Configure<App>().UsePlatformDetect().LogToTrace();}
}

2.3 API 概览

2.3.1 XAML布局

Avalonia的XAML布局功能类似于WPF,开发者可以使用XAML定义复杂的UI界面。以下是一个简单的XAML布局示例,其中包含一个按钮和一个文本框:

<Window xmlns="https://github.com/avaloniaui"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"><StackPanel><Button Content="Click Me" Click="ButtonClick"/><TextBox Text="{Binding Path=Name, Mode=TwoWay}"/></StackPanel>
</Window>
2.3.2 数据绑定

Avalonia支持多种数据绑定方式,如单向绑定、双向绑定等。下面是一个简单的数据绑定示例,其中文本框的内容与ViewModel中的属性进行双向绑定:

public class MainViewModel : ViewModelBase
{private string _name;public string Name{get => _name;set => this.RaiseAndSetIfChanged(ref _name, value);}
}// 在窗口代码中设置DataContext
this.DataContext = new MainViewModel();

更多关于Avalonia的API和使用方法,请参考Avalonia官方文档。

3. ReactiveUI:一个响应式编程库

ReactiveUI 是一个基于响应式编程原理的桌面应用框架,它提供了一种优雅的方��来处理用户界面和状态变化。通过结合响应式编程和 MVVM 模式,ReactiveUI 可以使得开发人员更容易地构建具有高度交互性和可维护性的桌面应用程序。

3.1 简介

3.1.1 核心功能

ReactiveUI 的核心功能包括:

  • 提供了一组响应式属性和命令绑定,简化了用户界面元素与数据模型之间的交互。
  • 支持异步编程模式,使得处理任务和事件变得更加便捷和灵活。
  • 提供了强大的路由机制,能够很好地处理导航和页面切换。
3.1.2 使用场景

ReactiveUI 适用于需要构建高度交互性、实时更新的桌面应用程序,尤其是需要处理复杂用户界面和数据流的场景。

3.2 安装与配置

3.2.1 安装指南

你可以通过 NuGet 来安装 ReactiveUI 包,以下为在 Visual Studio 中如何安装:

PM> Install-Package ReactiveUI

更多关于安装指南的信息可以参考 ReactiveUI 官方文档

3.2.2 基本设置

在使用 ReactiveUI 之前,需要进行一些基本设置,比如在应用程序启动时初始化 ReactiveUI:

public partial class App : Application
{public App(){this.InitializeReactiveUI();}
}

更多关于基本设置的内容可以参考 ReactiveUI 官方文档

3.3 API 概览

3.3.1 响应式属性

ReactiveUI 提供了一组便捷的 API 来创建和管理响应式属性。下面是一个简单的例子:

private string _name;
public string Name
{get => this._name;set => this.RaiseAndSetIfChanged(ref this._name, value);
}

以上代码演示了如何定义一个响应式属性 Name,并且使用 this.RaiseAndSetIfChanged 方法来通知属性值的变化。

更多关于响应式属性的API可以参考 ReactiveUI 属性绑定

3.3.2 命令绑定

ReactiveUI 也提供了便捷的 API 来实现命令绑定,以下是一个简单的例子:

public ReactiveCommand<Unit, Unit> GreetUser { get; }// 在构造函数中初始化命令
this.GreetUser = ReactiveCommand.CreateFromTask(async () =>
{await this._dialogService.ShowMessage("Hello, " + this.Name);
});

以上代码演示了如何定义一个命令 GreetUser 并通过 ReactiveCommand.CreateFromTask 来指定命令执行的异步操作。

更多关于命令绑定的 API 可以参考 ReactiveUI 命令绑定

通过上述示例,我们对 ReactiveUI 这个响应式编程库有了初步的了解。希望这篇文章对你有所帮助!

4. MahApps.Metro:一个现代化风格的WPF UI库

MahApps.Metro 是一个流行的开源桌面应用程序框架,它为 WPF 应用程序提供了现代化的用户界面设计和丰富的控件样式。通过 MahApps.Metro,开发人员可以轻松地为他们的应用程序添加漂亮的外观和新颖的交互功能。

4.1 简介

4.1.1 核心功能

MahApps.Metro 提供了丰富的现代化 UI 控件和样式,包括各种按钮、输入框、消息框、菜单等,同时还支持主题定制和国际化。此外,MahApps.Metro 还提供了一些实用的扩展功能,如窗口拖动、命令绑定等,以简化开发过程。

4.1.2 使用场景

MahApps.Metro 可以被广泛应用于需要现代化界面设计的 WPF 桌面应用程序中,尤其适合于企业内部管理系统、工具类软件等。

4.2 安装与配置

4.2.1 安装指导

首先,在 Visual Studio 中创建一个 WPF 项目。然后,在 NuGet 包管理器中搜索并安装 MahApps.Metro 包。

Install-Package MahApps.Metro
4.2.2 基本配置

在 App.xaml 文件中添加以下代码,引入 MahApps.Metro 主题:

<Application.Resources><ResourceDictionary><ResourceDictionary.MergedDictionaries><ResourceDictionary Source="pack://application:,,,/MahApps.Metro;component/Styles/Controls.xaml" /><ResourceDictionary Source="pack://application:,,,/MahApps.Metro;component/Styles/Fonts.xaml" /><ResourceDictionary Source="pack://application:,,,/MahApps.Metro;component/Styles/Colors.xaml" /></ResourceDictionary.MergedDictionaries></ResourceDictionary>
</Application.Resources>

4.3 API 概览

4.3.1 样式定义

MahApps.Metro 提供了一系列精美的控件样式定义,例如按钮、文本框、下拉列表等。开发者可以通过简单的 XAML 代码或者 C# 代码来使用这些样式。

<Button Style="{StaticResource MetroButton}" Content="Click Me" />

或者在 C# 代码中使用:

var button = new Button();
button.Style = FindResource("MetroButton") as Style;

更多样式定义,请参考 MahApps.Metro Styles。

4.3.2 控件模板

MahApps.Metro 还提供了丰富的控件模板,开发者可以根据自己的需求对控件的外观和交互行为进行定制。

<controls:TextBox Template="{StaticResource MetroTextBox}" />

或者在代码中应用模板:

var textBox = new TextBox();
textBox.Template = FindResource("MetroTextBox") as ControlTemplate;

有关更多控件模板的信息,请查看 MahApps.Metro Control Templates。

5. MaterialDesignInXAML:一个Material Design风格的XAML库

MaterialDesignInXAML是一个用于创建Material Design风格桌面应用的开源XAML库。它提供了一系列的控件和主题,可以帮助开发者快速构建现代化、美观的桌面应用程序。

5.1 简介

5.1.1 核心功能

MaterialDesignInXAML提供了丰富的Material Design风格控件,包括按钮、文本框、进度条等。同时,它还支持自定义主题,让开发者可以轻松实现应用程序的个性化定制。

5.1.2 使用场景

适用于需要在WPF应用中使用Material Design风格的开发者,尤其是那些希望快速搭建现代化界面的人群。

5.2 安装与配置

5.2.1 安装指南

首先,在Visual Studio中创建一个新的WPF项目。然后,可以通过NuGet包管理器来安装MaterialDesignInXAML。在NuGet包管理器控制台中执行以下命令:

Install-Package MaterialDesignThemes
5.2.2 基本设置

在WPF项目中,可以通过引入MaterialDesign的命名空间来使用其提供的控件和样式。在XAML文件中,可以通过下面的方式引入:

xmlns:materialDesign="http://materialdesigninxaml.net/winfx/xaml/themes"

5.3 API 概览

5.3.1 主题设置

MaterialDesignInXAML允许开发者通过修改主题颜色、字体大小等来自定义应用程序的外观。以下是一个示例,演示如何设置主题为深色:

var paletteHelper = new PaletteHelper();
var theme = paletteHelper.GetTheme();
theme.SetBaseTheme(Theme.Dark);
paletteHelper.SetTheme(theme);

更多关于主题设置的信息,请参考官方文档

5.3.2 控件使用

MaterialDesignInXAML提供了丰富的Material Design控件,例如按钮、文本框和进度条等。以下是一个简单的示例,展示如何使用Material Design风格的按钮:

<Button Style="{StaticResource MaterialDesignRaisedButton}" Content="Save" />

官方文档中还提供了更加详细的控件使用说明,可以通过这里找到更多信息。

以上是MaterialDesignInXAML库的简要介绍和基本使用方法,希望对您有所帮助。

6. Uno Platform:一个支持跨平台的XAML和C#解决方案

6.1 简介

Uno Platform 是一个支持使用 XAML 和 C# 跨平台开发的解决方案。它允许开发人员使用单一的代码库来构建适用于多个平台的应用程序,包括 iOS、Android、Windows 和 Web。

6.1.1 核心功能

Uno Platform 的核心功能包括跨平台的 XAML 布局系统和强大的数据绑定机制。开发人员可以使用熟悉的工具和语言来构建原生级别的用户界面,并实现数据模型与视图之间的无缝连接。

6.1.2 使用场景

Uno Platform 适用于需要在多个平台上构建一致性用户体验的项目。开发人员可以通过 Uno Platform 实现代码重用,并最大限度地减少针对不同平台的定制化开发工作量。

6.2 安装与配置

6.2.1 安装指南

要开始使用 Uno Platform,首先需要安装 Visual Studio 2019 或更高版本,并安装 Uno Platform 的 Visual Studio 插件。安装完成后,即可创建 Uno Platform 项目。

安装 Uno Platform 插件:

Extensions -> Manage Extensions -> Online -> Search for "Uno Platform" -> Install
6.2.2 基本设置

在 Visual Studio 中创建 Uno Platform 项目后,需要根据目标平台进行适当的配置。例如,对于 Android 平台,需要确保已经配置了正确的 Android 开发环境和模拟器。

6.3 API 概览

6.3.1 XAML布局

Uno Platform 的 XAML 布局系统类似于 UWP(Universal Windows Platform),支持使用标签和属性定义用户界面元素的布局和外观。

<Grid><TextBlock Text="Hello, Uno Platform!" />
</Grid>

官网链接:Uno Platform - XAML

6.3.2 数据绑定

Uno Platform 支持使用 C# 代码进行数据绑定,实现数据模型与视图之间的自动更新。

public class Person : INotifyPropertyChanged
{private string _name;public string Name{get { return _name; }set{if (_name != value){_name = value;RaisePropertyChanged(nameof(Name));}}}public event PropertyChangedEventHandler PropertyChanged;protected void RaisePropertyChanged(string propertyName){PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));}
}

官网链接:Uno Platform - Data Binding

总结

通过本文的介绍,我们对多个.NET桌面应用框架和UI库有了全面的了解。Eto.Forms提供跨平台的桌面应用开发解决方案,Avalonia则专注于.NET UI框架的跨平台实现。ReactiveUI支持响应式编程,MahApps.Metro和MaterialDesignInXAML则分别提供现代化风格和Material Design风格的UI组件。Uno Platform则是一个支持跨平台的XAML和C#解决方案。通过比较和总结,我们可以根据项目需求选取最适合的工具,以提升开发效率和用户体验。

相关文章:

【C#生态园】打造现代化跨平台应用:深度解析.NET桌面应用工具

选择最适合你的.NET UI框架&#xff1a;全面解析六种热门选择 前言 在现代软件开发中&#xff0c;选择合适的桌面应用框架和UI库对于开发人员来说至关重要。本文将介绍几种流行的.NET桌面应用框架和UI库&#xff0c;包括Eto.Forms、Avalonia、ReactiveUI、MahApps.Metro、Mat…...

第二十一章 (动态内存管理)

1. 为什么要有动态内存分配 2. malloc和free 3. calloc和realloc 4. 常⻅的动态内存的错误 5. 动态内存经典笔试题分析 6. 总结C/C中程序内存区域划分 1.为什么要有动态内存管理 我们目前已经掌握的内存开辟方式有 int main() {int num 0; //开辟4个字节int arr[10] …...

机器学习框架总结

机器学习框架是用于构建、训练、评估和部署机器学习模型的工具和库的集合。它们简化了模型开发过程&#xff0c;并提供了预构建的功能、优化的计算性能和对深度学习、监督学习、无监督学习等技术的支持。下面是一些主要的机器学习框架的详细介绍&#xff1a; 1. TensorFlow 1…...

docker pull 超时的问题如何解决

docker不能使用&#xff0c;使用之前的阿里云镜像失败。。。 搜了各种解决方法&#xff0c;感谢B站UP主 <iframe src"//player.bilibili.com/player.html?isOutsidetrue&aid113173361331402&bvidBV1KstBeEEQR&cid25942297878&p1" scrolling"…...

【数学分析笔记】第4章第3节 导数四则运算和反函数求导法则(2)

4. 微分 4.3 导数四则运算与反函数求导法则 双曲正弦函数 sh ⁡ x e x − e − x 2 \sh x\frac{e^x-e^{-x}}{2} shx2ex−e−x​ 双曲余弦函数 ch ⁡ x e x e − x 2 \ch x\frac{e^xe^{-x}}{2} chx2exe−x​ ch ⁡ 2 x − sh ⁡ 2 x 1 \ch^2 x-\sh^2 x1 ch2x−sh2x1 ( e…...

【2024】基于mysqldump的数据备份与恢复

基于mysqldump备份与恢复 mysqldump是一个用于备份 MySQL 数据库的实用工具。 它可以将数据库的结构&#xff08;如数据库、表、视图、存储过程等的定义&#xff09;和数据&#xff08;表中的记录&#xff09;导出为文本文件&#xff0c;这些文本文件可以包含 SQL 语句&#…...

家用无线路由器配置

一.首先进行线路连接。如下图&#xff1a;"光猫LAN口"—网线—"路由器WAN口"。 注意&#xff1a;家用光纤宽带一般选择使用200兆宽带到1000兆&#xff0c;如果网速不达标请查看路由器是否是千兆路由器。千兆路由器通常是双频的&#xff0c;支持两个信号一个…...

模拟算法(4)_外观数列

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 模拟算法(4)_外观数列 收录于专栏【经典算法练习】 本专栏旨在分享学习算法的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1. 题目链…...

vsomeip用到的socket

概述&#xff1a; ​ vsomeip用到的socket的代码全部都在implementation\endpoints目录下面&#xff0c;主要分布在下面六个endpoint类中&#xff1a; local_client_endpoint_impl // 本地客户端socket&#xff08;UDS Socket或者127.0.0.1的socket&#xff09;local_server…...

MFC有三个选项:MFC ActiveX控件、MFC应用程序、MFC DLL,如何选择?

深耕AI&#xff1a;互联网行业 算法研发工程师 ​ 目录 MFC ActiveX 控件 控件的类型 标准控件 自定义控件 ActiveX控件 MFC ActiveX控件 标准/自定义控件 MFC ActiveX控件分类 3种MFC如何选择&#xff1f; MFC ActiveX控件 MFC 应用程序 MFC DLL 总结 举例说明…...

边缘概率 | 条件概率

关于什么是边缘概率分布和条件概率分布&#xff0c;在理论上&#xff0c;我自己也还没有理解&#xff0c;那么现在就根据我学习到的理解方式来记录一下&#xff0c;有错误指出&#xff0c;请大家指正&#xff01;&#xff01;&#xff01; 例如&#xff0c;一个箱子里有十个乒乓…...

深入浅出:现代JavaScript开发者必知必会的Web性能优化技巧

亲爱的读者们&#xff0c;欢迎来到本期博客。今天&#xff0c;我们将深入探讨JavaScript开发者在日常工作中如何提升Web性能。在快节奏的Web开发世界中&#xff0c;性能优化至关重要。本文将分享一些实用技巧&#xff0c;帮助你构建快速、高效的Web应用。 1. 使用CDN加速资源加…...

【S32K3 RTD LLD篇5】K344 ADC SW+HW trigger

【S32K3 RTD LLD篇5】K344 ADC SWHW trigger 一&#xff0c;文档简介二&#xff0c;ADC SW HW 触发2.1 软硬件平台2.2 SWADC 软件触发2.3 SWBCTUADC 软件BCTU触发2.4 PITTRIGMUXADC 硬件PIT TRIGUMX触发2.5 EMIOSBCTUHWADC硬件EMIOS BCTU触发2.6 EMIOSBCTUHW LISTADC硬件EMIOS …...

TransFormer 视频笔记

TransFormer BasicsAttention单头注意力 single head attentionQ&#xff1a; query 查寻矩阵 128*12288K key matrix 128*12288SoftMax 归一 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/19e3cf1ea28442eca60d5fc1303921f4.png)Value matrix 12288*12288 MLP Bas…...

前端的混合全栈之路Meteor篇(三):发布订阅示例代码及如何将Meteor的响应数据映射到vue3的reactive系统

Meteor 3.0 是一个功能强大的全栈 JavaScript 框架&#xff0c;特别适合实时应用程序的开发。它的核心机制之一就包括发布-订阅&#xff08;Publish-Subscribe&#xff09;模型&#xff0c;它允许服务器端发布数据&#xff0c;客户端订阅并实时更新。本文将介绍如何在 Meteor 3…...

自动驾驶系列—颠覆未来驾驶:深入解析自动驾驶线控转向系统技术

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…...

Webstorm 中对 Node.js 后端项目进行断点调试

首先&#xff0c;肯定需要有一个启动服务器的命令脚本。 然后&#xff0c;写一个 debug 的配置&#xff1a; 然后&#xff0c;debug 模式 启动项目和 启动调试服务&#xff1a; 最后&#xff0c;发送请求&#xff0c;即可调试&#xff1a; 这几个关键按钮含义&#xff1a; 重启…...

VUE前后端分离毕业设计题目项目有哪些,VUE程序开发常见毕业论文设计推荐

目录 0 为什么选择Vue.js 1 Vue.js 的主要特点 2 前后端分离毕业设计项目推荐 3 后端推荐 4 总结 0 为什么选择Vue.js 使用Vue.js开发计算机毕业设计是一个很好的选择&#xff0c;因为它不仅具有现代前端框架的所有优点&#xff0c;还能让你专注于构建高性能、高可用性的W…...

一、Spring Boot集成Spring Security之自动装配

Spring Boot集成Spring Security之自动装配介绍 一、实现功能及软件版本说明二、创建Spring Boot项目三、查看自动装配配置类四、自动装配配置类之SecurityAutoConfiguration1、SecurityAutoConfiguration部分源码2、主要作用3、SpringBootWebSecurityConfiguration3.1、Spring…...

计数相关的题 Python 力扣

2284. 最多单词数的发件人 给你一个聊天记录&#xff0c;共包含 n 条信息。给你两个字符串数组 messages 和 senders &#xff0c;其中 messages[i] 是 senders[i] 发出的一条 信息 。 一条 信息 是若干用单个空格连接的 单词 &#xff0c;信息开头和结尾不会有多余空格。发件…...

Express内置的中间件(express.json和express.urlencoded)格式的请求体数据

目录 Express内置的中间件 express.json 中间件的使用 express.urlencoded 中间件的使用 express.urlencoded([options]) 解析req.body的兼容写法 Express内置的中间件 自 Express 4.16.0 版本开始&#xff0c;Express 内置了 3 个常用的中间件&#xff0c;极大的提高了 …...

cmakelist加载Qt模块

Qt编程中&#xff0c;cmakelist会自动添加Core&#xff0c;Gui&#xff0c;Widgets模块&#xff0c;有时需要添加新的Qt的模块。在命令find_package中搜索要新增的模块&#xff0c;在命令target_link_libraries中添加要新增的模块。 比如要使用QUiLoader类&#xff0c;要增加对…...

8-2.Android 任务之 CountDownTimer 编码模板(开启计时器、取消计时器)

一、CountDownTimer 1、概述 CountDownTimer 是 Android 中一个用于执行定时操作的类 CountDownTimer 主要应用于在指定时间段内完成某项任务&#xff0c;或者每隔一段时间触发某项任务 2、使用步骤 创建 CountDownTimer&#xff1a;创建 CountDownTimer 就是创建它的匿名…...

Servlet的生命周期及用户提交表单页面的实现(实验报告)

一、实验目的、要求 1. 掌握Servlet的定义&#xff0c;即Servlet是运行在服务器端的Java程序&#xff0c;用于扩展服务器的功能。 2. 学习和掌握在开发环境中搭建Servlet应用所需的工具&#xff0c;如Tomcat服务器、IDEA等。 二、实验内容 根据本章所学知识&#xff0c;实验…...

【Router】路由功能之IP过滤(IP Filter)功能(基于端口)介绍及实现

IP过滤(IP Filter) IP Filter是一种通过对网络数据包中的 IP 地址进行分析和筛选,以实现对网络流量的控制和管理的技术。 IP过滤(IP Filter)作用 安全防护 可以阻止来自特定 IP 地址或 IP 地址范围的恶意攻击、非法访问等,增强网络的安全性。 流量管理 根据不同的 IP …...

数据结构_2.2、顺序表插入删除查找

1、线性表的顺序存储表示定义&#xff1a; 线性表&#xff1a;是具有相同数据类型的n &#xff08;n≥0&#xff09;个数据元素的有限序列 顺序表&#xff1a;用顺序存储的方式实现线性表 顺序存储&#xff1a;把逻辑上相邻的元素存储在物理 位置上也相邻的存储单元中&#…...

嵌入式C语言自我修养:编译链接

源文件生成可执行文件的过程&#xff1f; 源文件经过预处理、编译、汇编、链接生成一个可执行的目标文件。 编译器驱动程序&#xff0c;包括预处理器、编译器、汇编器和链接器。Linux用户可以调用GCC驱动程序来完成整个编译流程。 使用GCC驱动程序将示例程序从ASCII码源文件转换…...

Mac制作Linux操作系统启动盘

前期准备 一个 Mac 电脑 一个 U 盘&#xff08;8GB 以上&#xff09; 下载好 Linux 系统镜像&#xff08;iso 文件&#xff09; 具体步骤 挂载 U 盘 解挂 U 盘 写系统镜像到 U 盘 完成 一、挂载 U 盘 首先插入 U 盘&#xff0c;打开终端输入下面的命令查看 U 盘是否已经 m…...

PHP语言发展历程

PHP是一种开源的服务器端脚本语言&#xff0c;主要用于Web开发&#xff0c;最初由Rasmus Lerdorf在1994年创建。PHP的发展历程如下&#xff1a; PHP的起源&#xff1a;1994年&#xff0c;Rasmus Lerdorf创建了PHP的第一个版本&#xff0c;最初是一套用于跟踪他个人简历访问的C…...

Notepad++ 之 AndroidLogger插件

背景 最近一段时间在分析Android log 定位问题&#xff0c;Notepad 之前用的比较少&#xff0c;现在看log觉得确实好用&#xff0c;美中不足的是 看Android log的时候不像 logcat -v color 可以区分不同等级的颜色&#xff0c;于是调研了一下&#xff0c;发现大部分都是使用An…...