我有一个带有object
属性和值类型ID号的模型,并想根据值类型号创建一个不同的编辑器控件。
我正在尝试使用@help
Razor 构造,但是没有任何辅助内容呈现到页面上。
@helper noEditor()
{
<div>noEditor</div>
}
@helper stringEditor()
{
<div>stringEditor</div>
}
@helper intEditor()
{
<div>intEditor</div>
}
@helper boolEditor()
{
<div>boolEditor</div>
}
@helper collectionEditor()
{
<div>collectionEditor</div>
}
@switch(Model.ValueTypeId)
{
case 1: stringEditor(); break;
case 2: intEditor(); break;
case 3: boolEditor(); break;
case 4: collectionEditor(); break;
default: noEditor(); break;
}
当我在
@switch
上放置一个断点时,我可以看到调试器移到了正确的帮助器上,但是它会立即跳到函数末尾,然后退出开关,什么都不会呈现。您对我在这里做错的任何想法吗?
最佳答案
要使用Razor渲染文本,您必须使用@符号。如果您将代码更改为
@switch(Model.ValueTypeId)
{
case 1: @stringEditor() break;
case 2: @intEditor() break;
case 3: @boolEditor() break;
case 4: @collectionEditor() break;
default: @noEditor() break;
}
它应该工作。
另外,您可以像这样使用
Response.Write
:@switch(Model.ValueTypeId)
{
case 1: Response.Write(stringEditor()); break;
case 2: Response.Write(intEditor()); break;
case 3: Response.Write(boolEditor()); break;
case 4: Response.Write(collectionEditor()); break;
default: Response.Write(noEditor()); break;
}
基本上是
@
在 Razor 中所做的。
关于asp.net-mvc - Razor @helper函数不呈现任何HTML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17950180/