.NET Core 编程指南中文版 —— 6.2 CLI变更概述 -> 使用 .NET Core SDK 1.0 管理依赖项

使用 .NET Core SDK 1.0 管理依赖项

在 .NET Core 项目从 project.json 移动到 csproj 和 MSBuild 的同时,还投入了大笔资金将项目文件和资产统一,以便跟踪依赖项。 对于 .NET Core 项目,这与 project.json 的做法类似。 没有单独的 JSON 或 XML 文件来跟踪 NuGet 依赖项。 通过这种改变,我们还在名为 <PackageReference> 的 csproj 语法中引入了另一种类型的引用。

本文档介绍了新的引用类型。 它还演示了如何使用此新引用类型将包依赖项添加到项目。

新 <PackageReference> 元素

<PackageReference> 具有下列基本结构:

<PackageReference Include="PACKAGE_ID" Version="PACKAGE_VERSION" />

如果你熟悉 MSBuild,则它看起来和已有的引用类型很相似。 关键是 Include 语句,它指定要添加到项目的包 ID。 <Version> 子元素指定要获取的版本。 根据 NuGet 版本规则指定版本。

 备注

如果不熟悉整体 csproj 语法,可参阅 MSBuild 项目参考文档了解详细信息。

使用类似以下示例中的条件添加仅在特定目标中可用的依赖项:

<PackageReference Include="PACKAGE_ID" Version="PACKAGE_VERSION" Condition="'$(TargetFramework)' == 'netcoreapp2.1'" />

上面的意思是,依赖项只有在对指定目标生成时才有效。 条件中的 $(TargetFramework) 是将在项目中设置的 MSBuild 属性。 对于大多数常见的 .NET Core 应用程序,无需这样做。

向项目添加依赖项

向项目添加依赖项非常简单。 下面是如何向项目添加 Json.NET 版本 9.0.1 的示例。 当然,它也适用于其他任意 NuGet 依赖项。

打开项目文件时,将看到两个或多个 <ItemGroup> 节点。 你会注意到其中一个节点已有 <PackageReference> 元素。 可以向此节点添加新的依赖项,或创建一个新的依赖项;这完全取决于你,因为其结果将是一样的。

在本示例中,将使用被 dotnet new console 删除的默认模板。 这是一个简单的控制台应用程序。 打开项目时,首先找到 <ItemGroup>,其中包含已存在的 <PackageReference>。 然后将下列内容添加进去:

<PackageReference Include="Newtonsoft.Json" Version="9.0.1" />

之后,保存项目并运行 dotnet restore 命令以安装依赖项。

 备注

从 .NET Core 2.0 SDK 开始,无需运行 dotnet restore,因为它由所有需要还原的命令隐式运行,如 dotnet newdotnet build 和 dotnet run。 在执行显式还原有意义的某些情况下,例如 Azure DevOps Services 中的持续集成生成中,或在需要显式控制还原发生时间的生成系统中,它仍然是有效的命令。

完整项目如下所示:

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
    <OutputType>Exe</OutputType>
    <TargetFramework>netcoreapp2.1</TargetFramework>
  </PropertyGroup>

  <ItemGroup>
    <PackageReference Include="Newtonsoft.Json" Version="9.0.1" />
  </ItemGroup>
</Project>

从项目中删除依赖项

从项目文件中删除依赖项仅包含从项目文件中删除 <PackageReference>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值