如何在razor语法中使用自定义的html属性

最近我想在

@Html.EditorFor(model => model.JobWant.Position, new
{
@class = "form-control", id = "JobWantPosition",@readonly=true,style="width:90%;float:left;"})

中增加3个属性,分别是data-id,data-multiple,data-bind。我是这样加入的:

 @Html.EditorFor(model => model.JobWant.Position, new
{
  @class = "form-control", id = "JobWantPosition",@readonly=true,style="width:90%;float:left;",data-id="JobWantPosition",data-multiple="true",data-bind="click:ShowSelectorJobClass"
  })      

因为这三个属性都是H5的自定义属性。razor语法根本不认,加入就报错。网上也找不到合适的方法,一说直接input,不用razor语法,另一种是用razor语法的templatename参数,构造模板。第一个不想用,因为页面用了bootstrap,用这个无法通过viewmodel传值。第二个我找了下构造templatename的方法,看着都头大,好复杂。后来我在stackoverflow网站看到有这样用的:

 @Html.FullFieldEditor(m => m.MyModel.MyRadioButton, new Dictionary<string, object> { { "data_bind", "checked:myRadioButton" } })

这给我了启发,但是由于我用的是mvc6,没有FullFieldEditor方法。可见是弃用了。我想应该有相似的方法。经过仔细寻找,觉得TextBoxFor方法或许可以满足要求。
这里写图片描述
构造的写法如下:

@Html.TextBoxFor(model => model.JobWant.Position, null, new Dictionary<string, object> { { "class", "form-control" }, { "id", "JobWantPosition" }, { "readonly", "true" }, { "style", "width:90%;float:left;" }, { "data-id", "JobWantPosition" }, { "data-multiple", "true" }, { "data-bind", "click:ShowSelectorJobClass" } })

刷新页面,页面没提示错误,然后点击,弹出窗口弹出正常。问题终于解决了

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值