• ASP.NET MVC Razor视图引擎


          Razor是asp.net MVC3的新扩展的内容,也是默认的视图引擎

          代码表达式

          Razor的核心转化字符是@,用来从标记到代码的转换(提出这个的肯定是个微博控,这样也简洁的不能在简洁了)

           例如

    @{
        
        string name = "zhangwei";
    }
    
    <h2>@name</h2>

    Razor的代码块可以自动的在标记和代码中转换,比如自动的识别<li></li>,而用{}可以包含一个代码块

    <ul>
     @foreach(var a in str)
     {
        <li>@a</li> 
     }
    </ul>

    解决二义性

        加入上面我想输出的是zhangwei.xxiu,代码就变成了

    @{
        
        string name = "zhangwei";
    }
    
    <h2>@name.xxiu</h2>

    很显然这里后面的.xxiu会被当作name的一个属性,于是需要一个括号来解决二义性

    @{
        
        string name = "zhangwei";
    }
    
    <h2>@(name).xxiu</h2>

    用双@号来解决如电子邮件 微博等需要输出@的内容

    <p>xxiu@@gmail.com</p>
    <a href="http://weibo.com/tlaozhang">@@张巍-程序员</a>

    Html编码

    Razor表达式使用了HTML 编码 

    例如

    @{
      string massage="<script>alert('hello zhangwei')</script>";
    }
    <h2>@massage</h2>


    如果正常输入的话将会弹出一个对话框,但事实上页面被处理成这样了 :

    <h2>&lt;script&gt;alert(&#39;hello zhangwei&#39;)&lt;/script&gt;</h2>


    如果需要输出弹出对话框的类,可以试用Html.Raw

    <h2>@Html.Raw( massage)</h2>

    注释试用

    @*要注释的内容*@

    Razor布局

    我们看模版文件_ViewStart.cshtml里只有下面一句话,Layout表示引用页面布局的路径 ,他是指一个默认的布局,我们可以根据需求修改这个路径  

    @{
        Layout = "~/Views/Shared/_Layout.cshtml";
    }

    在_layout.cs.html中有下面一段代码,关键在于@RenderBody() 用来占位主要内容的位置 ,这个和以前webFrom里的模版中留给页面的空间很相似。

      <div id="body">
                @RenderSection("featured", required: false)
                <section class="content-wrapper main-content clear-fix">
                    @RenderBody()
                </section>
            </div>

    边看边敲代码边记笔记的效率还是很高的,未完待续!

  • 相关阅读:
    阶段一 第一周 2-5 2-6 构建maven聚合工程
    阶段一 第一周 2-3 前后端分离开发模式讲解
    阶段一 第一周 2-2前后端技术选型
    Linux基础
    SpringMVC复习
    电商航线整理
    Mybatis整理复习
    python re正则
    爬虫基础 简单正则
    mysql 备份 恢复 事物 ER模型 pymysql交互
  • 原文地址:https://www.cnblogs.com/ac1985482/p/2807698.html
Copyright © 2020-2023  润新知