我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ASP.NET Core MVC中的标签TagHelper怎么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ASP.NET Core MVC中的标签TagHelper怎么用

本篇内容主要讲解“ASP.NET Core MVC中的标签TagHelper怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ASP.NET Core MVC中的标签TagHelper怎么用”吧!

1.什么是标签助手 Tag Helper

标签助手是服务端代码能够参与在 Razor 文件中创建和呈现HTML元素。例如,内置的 ImageTagHelper 可以将版本号追加到图像名称。无论何时更改图像,服务器都会为图像生成新的唯一版本,因此可以保证客户端获取当前图像(而不是过时的缓存图像)。内置的标签助手多用于常见任务,例如创建表单,链接和加载资源等。标签助手是在 C# 中定义的,它们基于元素名称,属性名称或父标签来定位HTML元素。例如,当应用 LabelTagHelper 特性时,内置的 LabelTagHelper  可以减少 Razor 视图中 HTML和 C# 之间的显示转换。

标签助手与HTML助手的差异:

* 标签助手提供了一HTML友好的开发体验

在大多数情况下,使用标签助手的 Razor 标记看起来像标准的 HTML。如果熟悉 HTML/CSS/Javascript的话,可以直接编辑 Razor,不需要学习C#语法。

* 丰富的IntelliSence 环境,用于创建 HTML 和 Razor 标记

HTML Helper 是此前在 Razor 视图中服务器端创建标记的方法。IntelliSense 支持 Tag HelpersIntelliSense 解释环境。即使有 Razor C# 语法经验的开发人员使用 Tag Helpers ,也比使用 C# Razor 标记更有效率。

还有一种更有效率的方法,并且能够使用尽在服务器上提供的信息生成更强大,可靠和可维护的代码。例如,以前更新图像的时候实在更改图象时更改图像名称。出于性能原因,应该清除缓存,除非更改图像名。内置的 ImageTagHelper 可以自动更改图像名称, ImageTagHelper 可将版本号追加到图像名称,因此每当更改图像时,服务器会自动为图像生成一个新的唯一的版本。保证客户端可以获取到当前图像。

大多数内置的标签助手均指向现有的 HTML 元素,并为元素提供服务端属性。例如,Views/Account 文件夹中许多使用的<input>元素包含 asp-for 属性,它将指定的模型属性的名称提取到呈现的 HTML 中。asp-for 属性有2 LabelTagHelper 中的 For 属性提供。

*管理标签助手范围

 标签助手范围由 @addTagHelper, @removeTagHelper 和 “!” 为推出字符串的组合控制。

@addTagHelper 使标签助手可用。默认 _ViewImports.cshtml 文件:

@using MVCTest@using MVCTest.Models@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers@addTagHelper "MVCTest.TagHelpers.EmailTagHelper,MVCTest"

上面的代码使用通配符语法(“ * ”)来指定程序集中的所有标签助手将可用于Views目录或子目录中的每个视图文件。@addTagHelper 之后的第一个参数指定要装载的标签助手,第二个参数 “Microsoft.AspNetCore.Mvc.TagHelpers” 指定包含标签助手的程序集。 Microsoft.AspNetCore.Mvc.TagHelpers 是内置的 ASP.NET Core 标签助手的程序集。

如果你的项目包含具有默认命名空间(AuthoringTagHelpers.TagHelpers.EmailTagHelper)的 EmailTagHelper,则可以提供标签助手的完全限定名(FQN):

@using MVCTest@using MVCTest.Models@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers@addTagHelper  “AuthoringTagHelpers.TagHelpers.EmailTagHelper,AuthoringTagHelpers”

 要想使用 FQN 向视图添加标签助手,请先添加 FQN (AuthoringTagHelpers.TagHelpers.EmailTagHelper),然后再添加程序集名称(AuthoringTagHelpers)。大多数开发人员喜欢使用 “*” 通配符语法。通配符语法允许在 FQN 中插入通配符 “*” 作为后缀。例如:

@addTagHelper  “AuthoringTagHelpers.TagHelpers.E *,AuthoringTagHelpers”@addTagHelper  “AuthoringTagHelpers.TagHelpers.Email *,AuthoringTagHelpers”

如果希望选择启用将标签助手仅显示给那些视图,则可以再特定视图中使用 @addTagHelper 指令。

* @removeTagHelper 删除标签助手

@removeTagHelper 具有与 @addTagHelper 相同的两个参数,它会删除之前添加的标签助手。例如,应用于特定视图的 @removeTagHelper 从视图中删除指定的标签助手。在Views/Floder/_ViewImports.cshtml 文件中使用  @removeTagHelper 从Floder 的所有视图中删除指定的标签助手。

*使用 _ViewImports.cshtml  文件控制标签助手范围

你可以将 ViewImports.cshtml  添加到任何视图文件夹,并且驶入引擎将来自 ViewImports.cshtml  文件的指令添加到 Views/ViewImports.cshtml 文件包含的指令中。如果为 Home 视图添加一个空的 ViewImports.cshtml  文件,则不会有任何改变,因为 ViewImports.cshtml  文件是叠加的。任何添加到 Views/Home/ViewImports.cshtml 文件的 @addTagHelper 指令都会使用这些标签助手仅显示在Home 文件夹中。

*选择退出个别元素

你可以使用标签助手退出符(“ ! ”)在元素级别停用标签助手。例如,使用标签助手退出符在<span>中禁用邮件验证:

<!span asp-validation-for="Email" class="text-danger"><!span>

必须将标签助手退出符应用于开始和结束标记。添加标签助手退出符后,元素和标签助手属性不再以特殊字体显示。

2.使用 @tagHelperPrefix 使标签助手显示使用

@tagHelperPrefix 指令允许你指定标签前缀字符串以启用标签助手支持,并使标签助手显示使用。例如下面代码,标签助手前缀设置为 th: ,因此只使用前缀为 th: support Tag Helper (启用标签助手的元素特殊字体)的元素。<label>和<input> 元素有标签助手前缀,并且启用了标签助手,而<sapn> 元素不启用:

<div class="form-group">                <th:label asp-for="Id" class="control-label"></th:label>                <th:input asp-for="Id" class="form-control" />                <span asp-validation-for="Id" class="text-danger"></span>            </div>

适用于 @addTagHelper 的相同层次结构规则也是用于 @tagHelperPrefix。

当在 VS 中创建一个 web 应用时,在 project.json 文件中添加 “Microsoft.AspNetCore.Razor.Tool”,这就是添加 Tag Helper 工具的包。

在 VS 编辑器中一输入 <l ,智能感知就会显示匹配的元素。智能感知语句允许用 Tab 键来输入所选值的语句。

你可以在属性值里面(双引号里)输入VS的CompleteWord快捷键(默认是Ctrl+空格),现在在C#中,就像一个C#类。智能感知显示页面模型的所有方法和属性,也可以帮助选择CSS类。

3.标签助手 Tag Helpers 和 HTML Helpers 比较

 标签助手是附加到 Razor 视图中的 HTML 元素,而 HTML 助手则是在 Razor 视图中穿插的 HTML 的方法调用。下面的 Razor 标记会创建一个带 CSS 类 “caption” 的HTML标签:

@Html.Label("FirstName", "First Name:", new {@class="caption"})

@符号告诉Razor这是代码的开始。接下来的两个参数(“FirstName” 和 “First Name:”)是字符串,因此IntelliSence 不能帮助。最后一个参数 new {@class="caption"} 是用于表示属性的匿名对象。因为 class 是C#中的关键字,所以使用@符号强制C#将@class=解释为符号。

使用LabelTagHelper,相同的标记可以写为:

<label asp-for="FirstName" class="caption"></label>

使用LabelTagHelper,只要在 VS 中输入 <l ,智能感知就会显示匹配的元素。

下面代码是 VS2015 中 ASP.NET 4.5.x MVC 模板生成的  Razor  视图表单部分:

@using (Html.BeginForm()){    @Html.AntiForgeryToken()        <div class="form-horizontal">        <h5>修改资料</h5>        <hr />        @Html.ValidationSummary(true, "", new { @class = "text-danger" })        @Html.HiddenFor(model => model.Id)        @Html.HiddenFor(model => model.Account)        <div class="form-group">            @Html.LabelFor(model => model.Id, htmlAttributes: new { @class = "control-label col-md-2" })            <div class="col-md-10" >                @Html.DisplayFor(model => model.Id, new { htmlAttributes = new { @class = "form-control" } })            </div>        </div>        <div class="form-group">            @Html.LabelFor(model => model.Account, htmlAttributes: new { @class = "control-label col-md-2" })            <div class="col-md-10" >                @Html.DisplayFor(model => model.Account, new { htmlAttributes = new { @class = "form-control" } })            </div>        </div>        <div class="form-group">            <div class="col-md-offset-2 col-md-10">                <input type="submit" value="保存" class="btn btn-default" />            </div>        </div>    </div>}

下面是 ASP.NET Core MVC 模板的标签助手表单部分代码:

<div class="col-md-4">        <form asp-action="Create">            <div asp-validation-summary="ModelOnly" class="text-danger"></div>            <div class="form-group">                <label asp-for="Id" class="control-label"></label>                <input asp-for="Id" class="form-control" />                <span asp-validation-for="Id" class="text-danger"></span>            </div>            <div class="form-group">                <label asp-for="Name" class="control-label"></label>                <input asp-for="Name" class="form-control" />                <span asp-validation-for="Name" class="text-danger"></span>            </div>            <div class="form-group">                <input type="submit" value="Create" class="btn btn-default" />            </div>        </form>    </div>

4.标签助手和 WEB 服务器控件比较

Web 服务器控件在页面上声明和调用。标签助手不拥有与其关联的元素,它们只是简单地参与元素和内容的呈现。

Web 服务器控件有一个不同的生命周期,使其开发和调试变得困难。

Web 服务器控件允许通过使用客户机空间向客户端文档对象模型(DOM)添加功能。标签助手没有DOM。

Web 服务器控件包括自动浏览器检测,标签助手不能识别浏览器。

多个标签助手可以对同一元素执行操作,但通常无法编写 Web 服务器控件。

标签助手可以修改其范围限定的HTML元素的标记和内容,但不直接修改页面上的任何其他内容。

Web 服务器控件使用类型转换器将字符串转为对象,有了标签助手,可以在C#中工作,不需要做类型转换。

Web 服务器控件使用 System.ComponentModel 来实现组件和控件的运行时和设计时行为。System.ComponentModel 包括用于实现属性和类转换器,绑定到数据源和许可组件的基类和接口。与标签助手相比,通常派生自 TagHelper,TagHelper基类仅公开 Process  和 ProcessAsync 两个方法。

5.自定义标签助手

 1.编写一个 email 标签助手

标签助手是任何实现ITagHelper 接口的类。然而,编写一个标签助手时,通常是从 TagHelper 类开始,这样可以访问 Process 方法。

首先创建一个 TagHelpers 文件夹,添加一个 EmailTagHelper 类:

public class EmailTagHelper:TagHelper    {        public override void Process(TagHelperContext context, TagHelperOutput output)        {            output.TagName = "a"; //用于将 <email> 替换为 <a>        }    }

注意:

* 标签助手使用以目标元素名作为根类名(出去类名中的TagHelper部分)的命名约定,EmailTagHelper最终对应的标签是 email 

* EmailTagHelper 类需派生自 TagHelper,重写 Process 方法

* Process 或 ProcessAsync 的上下文参数包含了与当前 HTML 标签执行的相关信息,输出参数包含了用来生成HTML标签和内容的源代码的静态HTML元素呈现。

类名后缀不是必须为TagHelper,但是建议加上。

下面在项目中使用 email 标签助手。在 _ViewImports.cshtml ,使用 addTagHelper 添加  EmailTagHelper类:

@using MVCTest@using MVCTest.Models@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers@addTagHelper "MVCTest.TagHelpers.EmailTagHelper,MVCTest"

@addTagHelper 之后的第一个字符串指明要加载的标签助手,第二个字符串指明此标签助手所在的程序集,在 Views/Home/Contact.cshtml 文件中加入标签:

@{    ViewData["Title"] = "Contact";}<h3>@ViewData["Title"]</h3><h4>@ViewData["Message"]</h4><address>    One Microsoft Way<br />    Redmond, WA 98052-6399<br />    <abbr title="Phone">P:</abbr>    425.555.0100</address><address>    <strong>Support:</strong> <email>Support</email><br />    <strong>Marketing:</strong> <email>Marketing</email></address>

运行程序并使用浏览器查看HTML代码,可以看到 email 标签都被替换成链接标签。但是没有一个 href 属性。

2.完善 email 标签助手

更新EmailTagHelper类:

public class EmailTagHelper:TagHelper    {        private const string EmailDomain = "contoso.com";        public string MailTo { get; set; } //增加 nail-to 属性,如 <email mail-to="..." />        public override void Process(TagHelperContext context, TagHelperOutput output)        {            output.TagName = "a"; //用于将 <email> 替换为 <a>            var address = MailTo + "@" + EmailDomain;            output.Attributes.SetAttribute("href","mailto:"+address);            output.Content.SetContent(address); //设置标签助手的内容        }    }

更新Views/Home/Contact.cshtml  ,加上 mail-to 属性:

@{    ViewData["Title"] = "Contact";}<h3>@ViewData["Title"]</h3><h4>@ViewData["Message"]</h4><address>    One Microsoft Way<br />    Redmond, WA 98052-6399<br />    <abbr title="Phone">P:</abbr>    425.555.0100</address><address>    <strong>Support:</strong> <email mail-to="Support">Support</email><br />    <strong>Marketing:</strong> <email mail-to="Marketing">Marketing</email></address>

以 Pascal  形式命名标签助手的类名及属性名会被翻译成它们的小写 kebab 形式。因此使用 MailTo 属性,与使用 <eamil mail-to="value" />。

3.异步标签助手

更新EmailTagHelper:

public class EmailTagHelper:TagHelper    {        private const string EmailDomain = "contoso.com";        public override async Task ProcessAsync(TagHelperContext context, TagHelperOutput output)        {            output.TagName = "a"; //用于将 <email> 替换为 <a>            var content = await output.GetChildContentAsync();            var target  = content.GetContent() + "@" + EmailDomain;            output.Attributes.SetAttribute("href", "mailto:" + target);            output.Content.SetContent(target);        }    }

Views/Home/Contact.cshtml :

@{    ViewData["Title"] = "Contact";}<h3>@ViewData["Title"]</h3><h4>@ViewData["Message"]</h4><address>    One Microsoft Way<br />    Redmond, WA 98052-6399<br />    <abbr title="Phone">P:</abbr>    425.555.0100</address><address>    <strong>Support:</strong> <email>Support</email><br />    <strong>Marketing:</strong> <email>Marketing</email></address>

到此,相信大家对“ASP.NET Core MVC中的标签TagHelper怎么用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ASP.NET Core MVC中的标签TagHelper怎么用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

ASP.NET Core MVC中的标签TagHelper怎么用

本篇内容主要讲解“ASP.NET Core MVC中的标签TagHelper怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ASP.NET Core MVC中的标签TagHelper怎么用”
2023-06-30

ASP.NET Core MVC中的视图怎么用

本篇内容介绍了“ASP.NET Core MVC中的视图怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!ASP.NET Core MVC
2023-06-30

ASP.NET Core MVC中的模型怎么使用

本篇内容介绍了“ASP.NET Core MVC中的模型怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.模型绑定ASP.NET C
2023-06-30

ASP.NET Core MVC中Form Tag Helpers怎么用

这篇文章主要介绍了ASP.NET Core MVC中Form Tag Helpers怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。简介HTML或Web表单通过使用各种H
2023-06-29

ASP.NET Core MVC路由怎么用

本篇内容介绍了“ASP.NET Core MVC路由怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ASP.NET Core MVC
2023-06-30

ASP.NET Core MVC中怎么实现过滤器

本篇内容介绍了“ASP.NET Core MVC中怎么实现过滤器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!过滤器如何工作?过滤器在 MV
2023-06-29

ASP.NET Core中MVC模式怎么实现路由

这篇“ASP.NET Core中MVC模式怎么实现路由”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ASP.NET Core
2023-06-29

在ASP.NET Core中怎么使用HTTP标头传播

这篇文章主要介绍“在ASP.NET Core中怎么使用HTTP标头传播”,在日常操作中,相信很多人在在ASP.NET Core中怎么使用HTTP标头传播问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”在ASP.
2023-06-30

ASP.NET Core中的Caching组件怎么用

本文小编为大家详细介绍“ASP.NET Core中的Caching组件怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.NET Core中的Caching组件怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习
2023-06-30

ASP.NET Core中的Configuration怎么配置

这篇文章主要讲解了“ASP.NET Core中的Configuration怎么配置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ASP.NET Core中的Configuration怎么配置
2023-06-29

ASP.NET Core中怎么使用多环境

本篇内容介绍了“ASP.NET Core中怎么使用多环境”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!ASP.NET Core 支持在多个环
2023-06-30

ASP.NET Core中怎么引用OpenAPI服务

这篇“ASP.NET Core中怎么引用OpenAPI服务”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ASP.NET Co
2023-06-30

ASP.NET MVC 3中的Razor特性怎么使用

本篇内容主要讲解“ASP.NET MVC 3中的Razor特性怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ASP.NET MVC 3中的Razor特性怎么使用”吧!开工 目录在_Vie
2023-06-17

怎么在asp.net项目中获取html标签的值

今天就跟大家聊聊有关怎么在asp.net项目中获取html标签的值,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。html有什么特点1、简易性:超级文本标记语言版本升级采用超集方式,从
2023-06-06

ASP.NET Core中的环境怎么配置

这篇文章主要介绍了ASP.NET Core中的环境怎么配置的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇ASP.NET Core中的环境怎么配置文章都会有所收获,下面我们一起来看看吧。1.环境变量配置ASP.N
2023-06-29

Lamar怎么在ASP.Net Core项目中使用

这篇文章将为大家详细讲解有关Lamar怎么在ASP.Net Core项目中使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。为什么要用 Lamar 实现依赖注入要说 .NET 世界最早的依赖
2023-06-13

ASP.NET Core中怎么使用UEditor编辑器

ASP.NET Core中怎么使用UEditor编辑器,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.安装UEditorNetCoreInstall-Pack
2023-06-17

怎么在Docker中部署 ASP.NET Core应用

本篇文章为大家展示了怎么在Docker中部署 ASP.NET Core应用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、系统环境1、腾讯云轻量应用服务器CentOS7.6二、操作流程及途中遇到的
2023-06-15

ASP.NET MVC中怎么使用Oauth2.0验证身份

这期内容当中小编将会给大家带来有关ASP.NET MVC中怎么使用Oauth2.0验证身份,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1. OAuth3.0中的角色  ● Resource Owner:
2023-06-19

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录