vscode中Razor标签不起作用

<form method="POST">
    <div asp-validation-summary="All" ></div>
    <div>Name:<input asp-for= "Customer.Name"/> </div>
    <span asp-validation-summary="Customer.Name"></span>
    <input type="submit"/>
</form>

后来验证总是提示Name属性未被赋值。一番检查后发现是Razor标签(这里指的是asp-for)没起作用,需要在.csproj文件中添加包引用:

<PackageReference Include="Microsoft.AspNetCore.Mvc.TagHelpers" Version="2.2.0"/>

version可以先填1.0.1,它会自动提示你最新的版本是多少,根据需要进行更新即可。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在最新版本的 ASP.NET Core Razor 模板引擎不再支持 `@helper` 关键字。`@helper` 关键字用于定义可重复使用的代码块,但现在已经被废弃了。 如果你想在 Razor 定义可重复使用的代码块,可以使用部分视图(Partial View)或自定义标签助手(Tag Helper)来实现相同的目的。 1. 部分视图(Partial View):可以在 Razor 页面创建一个部分视图,然后在需要使用的地方通过 `@Html.Partial` 或 `@await Html.PartialAsync` 来引用它。部分视图可以包含自己的代码和模型,并且可以在多个页面重复使用。 2. 自定义标签助手(Tag Helper):可以创建一个自定义的标签助手类,在其定义可重复使用的代码块,并通过在 Razor 页面使用自定义标签来调用它。标签助手可以带有自己的属性,并且可以通过参数传递数据。 下面是一个示例,展示如何使用部分视图和自定义标签助手来替代 `@helper`: 1. 使用部分视图: 在 `Shared` 文件夹下创建一个名为 `_Greeting.cshtml` 的部分视图文件,内容如下: ```razor @model string <p>Hello, @Model!</p> ``` 然后,在需要使用的 Razor 页面通过 `@Html.Partial` 调用该部分视图: ```razor @{ var name = "John"; } @Html.Partial("_Greeting", name) ``` 2. 使用自定义标签助手: 创建一个名为 `GreetingTagHelper.cs` 的自定义标签助手类,内容如下: ```csharp using Microsoft.AspNetCore.Razor.TagHelpers; [HtmlTargetElement("greeting")] public class GreetingTagHelper : TagHelper { public string Name { get; set; } public override void Process(TagHelperContext context, TagHelperOutput output) { output.TagName = "p"; output.Content.SetContent($"Hello, {Name}!"); } } ``` 然后,在需要使用的 Razor 页面使用 `greeting` 标签调用该标签助手: ```razor <greeting name="John" /> ``` 通过使用部分视图或自定义标签助手,你可以在 Razor 页面实现类似于 `@helper` 的可重复使用代码块的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值