微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在View中全局设置变量?

如何解决如何在View中全局设置变量?

我需要在View中将以下代码定义为全局变量,然后可以在单独的JS代码中使用该值。我不知道该怎么做,我尝试了各种方法

<td class="choice">

       @Html.TextBoxFor(modelItem => item.ManualDate,new { @type = "date",@class = "form-control datepicker" }) //I want this @Html... to be global and available in .js file
</td>

那么我的View的这一部分应该在部分View顶部的某个地方声明?大括号?

@{
    ViewBag.Title = "myTitle";
    Layout = "~/Views/Shared/_Layout.cshtml";
    var globalVar = "@Html.TextBoxFor(modelItem => item.ManualDate,new { @type = 'date',@class = 'form-control datepicker' })";

}

我在.js文件中引用了它,但是它不能正常工作(在“选择”数据字段字符串中显示而不是razor元素):

finalChoice.innerHTML = '@Model.globalVar'

解决方法

诸如 @Html.TextBoxFor @Model之类的剃刀语法只能由服务器解析,而不能由JavaScript解析。在@{//...}中使用变量将被解析为字符串。父页面中的JavaScript文件可以直接调用部分视图中的元素。

@Html.TextBoxFor可以放置在视图中。但是,如果您不想在视图中显示它,请将其样式设置为隐藏。然后,您可以通过其ID获取该元素。

在_part.cshtml(局部视图)中

<div id="part">
  @Html.TextBoxFor(modelItem => modelItem.ManualDate,new { @type = "date",@class = 
  "form-control datepicker" })
</div>

example

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