Sparkdo.Specifications
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.Specifications --version 1.0.1
NuGet\Install-Package Sparkdo.Specifications -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.Specifications" Version="1.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Sparkdo.Specifications" Version="1.0.1" />
<PackageReference Include="Sparkdo.Specifications" />
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.Specifications --version 1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Sparkdo.Specifications, 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.Specifications@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.Specifications&version=1.0.1
#tool nuget:?package=Sparkdo.Specifications&version=1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Sparkdo Specifications
Sparkdo Specifications 是一个实现了规格模式(Specification Pattern)的 .NET 类库。该库提供了一种灵活且可组合的方式来定义业务规则和查询条件。
功能特性
- 完整的规格模式实现:包括基础规格、组合规格和各种逻辑操作
- LINQ 表达式支持:所有规格都可以转换为 LINQ 表达式,便于与 Entity Framework 等 ORM 集成
- 流畅的 API:通过扩展方法提供链式调用语法
- 高性能:支持表达式组合和参数重绑定,避免常见的 Entity Framework 性能问题
核心组件
基础接口和类
ISpecification<T>:规格的基础接口Specification<T>:规格的抽象基类ExpressionSpecification<T>:从 LINQ 表达式创建的规格AnySpecification<T>:始终返回 true 的规格NoneSpecification<T>:始终返回 false 的规格
组合规格
AndSpecification<T>:AND 组合规格OrSpecification<T>:OR 组合规格NotSpecification<T>:NOT 规格(反转)AndNotSpecification<T>:AND NOT 组合规格
辅助类
SpecificationBuilder:创建规格的便捷方法SpecificationExtensions:规格的扩展方法ExpressionFuncExtender:表达式扩展方法
使用示例
基础用法
// 创建一个简单的规格
var spec = new ExpressionSpecification<Person>(p => p.Age >= 18);
// 检查对象是否满足规格
bool isSatisfied = spec.IsSatisfiedBy(person);
组合规格
// 创建多个规格
var ageSpec = new ExpressionSpecification<Person>(p => p.Age >= 18);
var nameSpec = new ExpressionSpecification<Person>(p => p.Name.StartsWith("A"));
// 组合规格
var combinedSpec = ageSpec.And(nameSpec);
使用 SpecificationBuilder
// 使用便捷方法创建规格
var spec = SpecificationBuilder.PropertyEquals<Person, int>(p => p.Age, 25);
转换为 LINQ 表达式
// 将规格转换为 LINQ 表达式,用于 Entity Framework 查询
var expression = spec.ToExpression();
var adults = context.People.Where(expression);
扩展方法
该库提供了丰富的扩展方法,支持链式调用:
And():AND 组合Or():OR 组合AndNot():AND NOT 组合Not():NOT 操作(反转)
| 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.Core (>= 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.Core (>= 1.0.1)
- System.Linq.Dynamic.Core (>= 1.7.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Sparkdo.Specifications:
| Package | Downloads |
|---|---|
|
Sparkdo.Ddd.Domain
Sparkdo DDD 领域模型库,提供领域驱动设计的核心组件实现 |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.2-preview.4 | 76 | 2/8/2026 |
| 1.0.2-preview.3 | 85 | 2/1/2026 |
| 1.0.2-preview.2 | 94 | 1/31/2026 |
| 1.0.2-preview.1 | 177 | 12/4/2025 |
| 1.0.1 | 789 | 11/27/2025 |
| 1.0.0 | 751 | 11/25/2025 |
| 1.0.0-preview.5 | 125 | 10/24/2025 |