ASP.NET MVC将模型数据传给JavaScript函数问题

5 篇文章 0 订阅
2 篇文章 0 订阅

使用APS.NET MVC编写页面,在Html中为javascript函数传入的参数为动态数据时,要注意将动态参数放在引号中,如下面代码中超链接的add函数所示。

<tbody>
  @{ int i = 1;}
  @foreach (Permission p in Model)
  {
    <tr>
      <td><input type="checkbox" data-code="@p.Code" data-desc="@p.Description"/></td>
       <td>@(i++)</td>
       <td>@p.Code</td>
       <td>@p.Description</td>
       <td><a onclick="add('@p.Code', '@p.Description');" style="cursor:pointer;">导入</a></td>
     </tr>
  }
</tbody>

原因如下:
如果直接将模型数据传入,那么最终的显示是这些数据被当做了变量名,会发生报错,页面源码如下。

<tr>
  <td><input type="checkbox" data-code="Permission-AddAll" data-desc="添加选择的权限到系统"/></td>
  <td>4</td>
  <td>Permission-AddAll</td>
  <td>添加选择的权限到系统</td>
  <td><a onclick="add(Permission-AddAll, 添加选择的权限到系统);" style="cursor:pointer;">导入</a></td>
</tr>

而用引号引起来后的页面源码如下:

<tr>
  <td><input type="checkbox" data-code="Permission-AddAll" data-desc="添加选择的权限到系统"/></td>
  <td>4</td>
  <td>Permission-AddAll</td>
  <td>添加选择的权限到系统</td>
  <td><a onclick="add('Permission-AddAll', '添加选择的权限到系统');" style="cursor:pointer;">导入</a></td>
</tr>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值