@helper的使用

@helper的使用、前言最近翻到一篇Scott的旧文,觉得挺不错的,就试着翻译了一下,文章主要是说如何在Razor中使用@helper语法定义可复用的视图模板方法。如有疏漏,还请请各位看官指点一二~原文地址:http:

大家好,又见面了,我是你们的朋友全栈君。

 

、前言

最近翻到一篇Scott的旧文,觉得挺不错的,就试着翻译了一下,文章主要是说如何在Razor中使用@helper语法定义可复用的视图模板方法。如有疏漏,还请请各位看官指点一二~

原文地址:http://weblogs.asp.net/scottgu/archive/2011/05/12/asp-net-mvc-3-and-the-helper-syntax-within-razor.aspx

2、正文

Asp.net MVC 3提供了一个全新的视图引擎(View-engine)叫做Razor(同时也继续提供并增强了对现有的.aspx视图引擎的支持)。Razor最大程度的减少了编写视图模板(译者注:前端页面)时需要输入的字符数和键盘敲击次数,提供了一个快速和流畅的编码体验。

与大多数模板语言不同,使用Razor你不在需要使用一些开始和关闭标记来打断你的编码(译者注:像aspx的<% %>),Razor的语法分析器能够智能的识别代码。这样的语法紧凑而简洁,输入起来轻松愉快。

你可以从我这9个月以来发表的一些文章来了解关于Razor的更多信息:

今天的文章主要是讨论一个不甚为人所知的特性:使用@helper语法定义可重用的helper方法

@helper语法让你可以轻松在视图模板中创建可重用的帮助方法,以此来封装一些负责向页面进行输出的功能。使用这项技术你将可以写出可读性更好的代码,并抽象出可重用的帮助方法。让我们来看一个最简单的例子:

首先看一个展示产品列表的简单场景:显示产品的名称和价格——如果产品没有价格,则显示“FREE”

clip_image001

可以看到上面的代码非常直白,并且Razor的语法使得HTML与服务端C#代码结合的更加自然和易懂。

只有一个地方看起来有些别扭,就是针对价格的”If else”逻辑。如果我们需要在另外一个页面显示产品的价格,就不得不再写一遍上面的判断逻辑,每一个地方都可能出现错误,导致代码难以维护且臃肿。

这种情况就需要把判断价格的逻辑抽出来形成helper方法。

让我们把价格判断逻辑封装起来,使用一个”DisplayPrice”helper方法来表示它:

clip_image001[10]

我们已经使用@helper语法定义了一个可重用的DisplayPrice方法,就好像标准C#/VB代码一样,它可以包含任意数量的参数(你也可以定义可空类型参数)。与标准C#/VB代码不同的是,你除了可以写服务端代码以外,还可以写入HTML,以及其他Razor支持的语法。

clip_image002

你可以像调用标准C#或VB代码一样调用它们

clip_image003

VS也同样会为它生成智能提示信息:

clip_image004

下面来讨论在多个视图页面共享helper方法:

在上面的例子中,我们定义了自己的helper方法,该方法与调用代码在同一个视图模板中。我们其实可以将方法定义在视图模板外部,并且让它可以被所有的视图模板所公用。

要实现这个功能,我们需要把定义helper方法的文件放在App_Code目录下。这个目录通常应该在项目根目录下。

比如我创建了一个叫做“ScottGu.cshtml”的文件,并且定义了2个方法在里面(你可以在一个文件中定义任意多个helper方法):

clip_image005

一旦我们在App层面定义了这些方法,我们就可以在应用程序的任何视图模板中使用它们。

ScottGu.cshtml模板文件将会自动编译为一个叫做ScottGu的类,并且包含2个静态方法: “DisplayPrice” 和“AnotherHelper” 。

我们可以像下面这样调用它们:

clip_image006

Visual Studio会为我们提供智能感知提示:

clip_image007

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155046.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月3日 下午10:46
下一篇 2022年7月3日 下午10:46


相关推荐

  • spring操作transactionManager

    spring操作transactionManager

    2026年3月18日
    2
  • ZMQ 指南_广州南沙区全员核酸检测

    ZMQ 指南_广州南沙区全员核酸检测ZMQ指南原文github连接 作者:PieterHintjens ph@imatix.com,CEOiMatixCorporation. 翻译:张吉 jizhang@anjuke.com,安居客集团好租网工程师WiththankstoBillDesmarais,BrianDorsey,CAF,DanielLin,EricDesgranges,Gonzal…

    2025年6月9日
    4
  • 在ubuntu安装的软件在哪里找_ubuntu如何安装gcc编译器

    在ubuntu安装的软件在哪里找_ubuntu如何安装gcc编译器在ubuntu安装vscode和可视化的代码跟踪调试在ubuntu安装vscode一、命令安装1.在网页下载deb安装包:https://code.visualstudio.com/Download2.在命令行安装:3.在命令行执行:二、汉化在ubuntu中用vscode编译调试C\C++一、安装插件二、编译运行程序在ubuntu安装vscode一、命令安装1.在网页下载deb安装包:https://code.visualstudio.com/Download2.在命令行安装:

    2025年12月15日
    6
  • GPIB + C编程

    GPIB + C编程一个 GPIB 的操作类 采用 Adlink 的 GPIB 板卡 使用 Adlink 提供的 C 类 只是调用 DLL 封装了一下 类中包括对安捷伦数字万用表的基本操作 对固纬程控电源的基本操作和程控变阻箱的基本操作 usingSystem usingSystem Collections Generic usingSystem Text usingSystem Threading namespa

    2026年3月17日
    3
  • Windows Server 2012 域控服务器连接转换服务器实现office服务功能

    Windows Server 2012 域控服务器连接转换服务器实现office服务功能nbsp 由于需求点上需要接入 office 相关功能 所以学习了搭建 windowsserve 相关知识点 以下是从 0 到有的一个过程配置信息 WindowsServe 版本 windows server 2012 OfficeOnline 版本 OfficeOnline 一 需要 2 台 windowsserve 的虚拟机 镜像的话这边上

    2025年10月25日
    5
  • php memcache 数组,PHP Memcache

    php memcache 数组,PHP MemcacheMemcache memcache 是一套分布式的高速缓存系统 目前被许多网站使用提升网站的访问速度 尤其是对于一些大型的 需要频繁访问数据库的网站访问速度提升效果很明显 具体是在内存中维护一个巨大的 hash 表 简单的说就是将数据调用到内存中 然后从内存中读取 就能大大提高读取速度 工作流程 先检查客户端请求的数据是否在 memcached 中 如有 将数据直接返回 不再对数据库进行操作 请求数据不存在

    2025年11月18日
    12

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号