Sparkdo.ObjectExtending
1.0.1
.NET 10.0
This package targets .NET 10.0. The package is compatible with this framework or higher.
.NET Standard 2.0
This package targets .NET Standard 2.0. The package is compatible with this framework or higher.
There is a newer prerelease version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package Sparkdo.ObjectExtending --version 1.0.1
NuGet\Install-Package Sparkdo.ObjectExtending -Version 1.0.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Sparkdo.ObjectExtending" Version="1.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Sparkdo.ObjectExtending" Version="1.0.1" />
<PackageReference Include="Sparkdo.ObjectExtending" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Sparkdo.ObjectExtending --version 1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Sparkdo.ObjectExtending, 1.0.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Sparkdo.ObjectExtending@1.0.1
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Sparkdo.ObjectExtending&version=1.0.1
#tool nuget:?package=Sparkdo.ObjectExtending&version=1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Sparkdo.ObjectExtending
Sparkdo 对象扩展模块,提供对象属性扩展功能。
功能特性
- 对象属性动态扩展
- 扩展属性验证
- 本地化扩展属性显示名称和描述
- 与 Sparkdo 框架无缝集成
安装
<PackageReference Include="Sparkdo.ObjectExtending" Version="x.x.x" />
核心组件
ObjectExtending
IWithExtraProperties: 标识对象具有扩展属性的接口ExtraPropertyDictionary: 扩展属性字典IExtensionPropertyPolicyChecker: 扩展属性策略检查器接口ExtensionPropertyPolicyChecker: 扩展属性策略检查器实现
扩展属性定义
ExtensionPropertyInfo: 扩展属性信息ExtensionPropertyAttribute: 扩展属性特性ExtensionPropertyConfiguration: 扩展属性配置
验证
ExtensionPropertyValidationContext: 扩展属性验证上下文ExtensionPropertyValidationResult: 扩展属性验证结果
使用方法
基本对象扩展
public class MyEntity : IWithExtraProperties
{
public ExtraPropertyDictionary ExtraProperties { get; } = new();
}
// 使用扩展属性
var entity = new MyEntity();
entity.SetProperty("CustomProperty", "CustomValue");
var value = entity.GetProperty<string>("CustomProperty");
扩展属性配置
// 配置扩展属性
var property = new ExtensionPropertyInfo(
"CustomProperty",
typeof(string),
new ExtensionPropertyConfiguration
{
DisplayName = new FixedLocalizableString("自定义属性"),
Description = new FixedLocalizableString("这是一个自定义属性"),
Validators = new[]
{
new ExtensionPropertyValidationContext
{
Name = "StringLength",
Value = 100
}
}
});
扩展性
该库提供了完整的对象扩展功能实现,可以通过以下方式扩展:
- 实现自定义的
IExtensionPropertyPolicyChecker来提供特定的扩展属性策略检查逻辑 - 实现自定义的验证逻辑来验证扩展属性
- 实现自定义的本地化逻辑来提供扩展属性的本地化显示
代码结构说明
本项目包含以下主要组件:
对象扩展核心
IWithExtraProperties: 标识对象具有扩展属性的接口ExtraPropertyDictionary: 扩展属性字典实现ObjectExtensionManager: 对象扩展管理器ObjectExtensionPropertyInfo: 对象扩展属性信息
扩展属性策略检查
IExtensionPropertyPolicyChecker: 扩展属性策略检查器接口ExtensionPropertyPolicyChecker: 扩展属性策略检查器实现
扩展属性定义
ExtensionPropertyInfo: 扩展属性信息类ExtensionPropertyAttribute: 扩展属性特性ExtensionPropertyConfiguration: 扩展属性配置类
验证相关
ExtensionPropertyValidationContext: 扩展属性验证上下文ExtensionPropertyValidationResult: 扩展属性验证结果
所有公共接口和类都添加了详细的 XML 文档注释,便于开发者理解和使用。
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- JetBrains.Annotations (>= 2025.2.2)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.0)
- Microsoft.Extensions.Configuration (>= 10.0.0)
- Microsoft.Extensions.Configuration.CommandLine (>= 10.0.0)
- Microsoft.Extensions.Configuration.EnvironmentVariables (>= 10.0.0)
- Microsoft.Extensions.Configuration.FileExtensions (>= 10.0.0)
- Microsoft.Extensions.Configuration.Json (>= 10.0.0)
- Microsoft.Extensions.Configuration.UserSecrets (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.0)
- Microsoft.Extensions.DependencyModel (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Physical (>= 10.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Localization (>= 10.0.0)
- Microsoft.Extensions.Logging (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.0)
- Nito.AsyncEx.Context (>= 5.1.2)
- Sparkdo.Localization.Abstractions (>= 1.0.1)
- Sparkdo.Validation.Abstractions (>= 1.0.1)
- System.Linq.Dynamic.Core (>= 1.7.0)
- System.Runtime.Loader (>= 4.3.0)
- System.Text.Json (>= 10.0.0)
-
net10.0
- JetBrains.Annotations (>= 2025.2.2)
- Microsoft.Extensions.Configuration (>= 10.0.0)
- Microsoft.Extensions.Configuration.CommandLine (>= 10.0.0)
- Microsoft.Extensions.Configuration.EnvironmentVariables (>= 10.0.0)
- Microsoft.Extensions.Configuration.FileExtensions (>= 10.0.0)
- Microsoft.Extensions.Configuration.Json (>= 10.0.0)
- Microsoft.Extensions.Configuration.UserSecrets (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.0)
- Microsoft.Extensions.DependencyModel (>= 10.0.0)
- Microsoft.Extensions.FileProviders.Physical (>= 10.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Localization (>= 10.0.0)
- Microsoft.Extensions.Logging (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.0)
- Nito.AsyncEx.Context (>= 5.1.2)
- Sparkdo.Localization.Abstractions (>= 1.0.1)
- Sparkdo.Validation.Abstractions (>= 1.0.1)
- System.Linq.Dynamic.Core (>= 1.7.0)
NuGet packages (10)
Showing the top 5 NuGet packages that depend on Sparkdo.ObjectExtending:
| Package | Downloads |
|---|---|
|
Sparkdo.EventBus.Abstractions
Sparkdo 事件总线抽象库,提供事件发布/订阅模式的核心接口定义 |
|
|
Sparkdo.Json.SystemTextJson
Sparkdo SystemTextJson模块,提供基于System.Text.Json的JSON序列化和反序列化功能,支持自定义转换器、日期时间标准化处理、枚举序列化、扩展属性序列化等特性。 |
|
|
MYDev.Fadada
.NET SDK for 法大大 (Fadada) 电子签章服务,提供企业级电子合同签署解决方案。支持企业成员管理、文件处理、印章管理、签署任务等核心功能。 |
|
|
MYDev.ShortUrls
Package Description |
|
|
Sparkdo.TenantManagement.Domain.Shared
Sparkdo 租户管理共享资源和配置 |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.2-preview.1 | 166 | 12/4/2025 |
| 1.0.1 | 2,452 | 11/27/2025 |
| 1.0.0 | 2,311 | 11/25/2025 |
| 1.0.0-preview.5 | 109 | 10/24/2025 |