将不确定变为确定~Razor视图中是否可以嵌套JS代码

回到目录

这个问题有点意思,Razor的自动闭合性,导致JS代码不能直接与Razor代码混排,原来ASPX页面中,我们到处可见这种代码

复制代码
  <%
           if(Model!=null){
           foreach (var item in Model.Res_ResourceProperty_Ext.GroupBy(i => i.PlatformID))
            {
              string vidArr="";
              string vidNameArr="";
              foreach (var sub in item)
               {
                vidArr+=sub+",";
                vidNameArr+=(new Service.EEE114.Common_BasePropValueService().GetCommon_BasePropValueByID(sub.VID ?? 0)!=null?new Service.EEE114.Common_BasePropValueService().GetCommon_BasePropValueByID(sub.VID ?? 0).Name:"")+",";
               }
           %>
            var source = html.replace(reg, function (node, key) {
                return {
                    'Platform_SubValValue': '<%=item.Key %>',
                    'Platform_SubValID': 'Platform_SubVal' + '<%=item.Key %>',
                    'platform': '<%=((Platform)item.Key).GetDescription()%>',
                    'VIDValue': '<%=vidArr %>',
                    'VIDDisplayName': '<%=vidNameArr %>'
                }[key];
            });
            $("#selection").append(source);
            <%} 
             }%>
复制代码

而如果是Razor页面,这种写法,显然是行不通的,因为JS变量直接混在了Razor块中,使得系统无法辨认JS,事实上,我们在razor中,可以加入<script>块

来解决这个问题,上面的代码在Razor视图中,可以类似于这样

复制代码
@if (Model != null)
{
    foreach (var item in Model.WebManageRoles.GroupBy(i => i.DepartmentID))
    {

        foreach (var sub in item)
        {
    <script type="text/javascript">
        var reg = new RegExp("\\[([^\\[\\]]*?)\\]", 'igm'); //i g m是指分别用于指定区分大小写的匹配、全局匹配和多行匹配。
        var html = document.getElementById("commentTemplate").innerHTML;
        var source = html.replace(reg, function (node, key) {
            return {
                'Platform_SubValValue': '@item.Key',
                'Platform_SubValID': 'Role' + '@item.Key',
                'platform': '@item.Key',
                'VIDValue': '@sub.ManageRoleID',
                'VIDDisplayName': '@sub.RoleName'
            }[key];
        });
        $("#Selection").append(source);
    </script>
        }
    }
}
复制代码

这种代码,我们感觉比ASPX里的排版更加清晰了,呵呵!

感谢Razor!

回到目录

posted @   张占岭  阅读(6484)  评论(6编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
点击右上角即可分享
微信分享提示