Razor视图中的@:和语法

Razor视图中的@:和语法

原创changuncle 最后发布于2016-12-07 17:43:50 阅读数 4456  收藏

展开

在MVC项目中新建视图的时候默认支持ASPX引擎和Razor引擎,如果选择ASPX引擎,那它跟webform项目中的*.aspx前台页面没区别,如果选择Razor引擎,那我们可以用更少的代码来实现相同的功能(与使用ASPX引擎相比较),我们不用在HTML中明确地标记出服务模块的结束标志,因为Razor解析器足够聪明,它可以自己推断出来。

HTML代码与C#代码混编

1、在前台声明和使用C#变量

如果想在前台声明C#变量,那声明C#变量的代码必须写在@{ }代码块中,使用@+C#变量名就能取得C#变量的值,注意前后必须有空格,否则会被当做普通字符输出。

混编代码:

浏览器截图:

2、前台利用foreach循环输出

@+C#变量名,表示获取C#变量的值;@+C#语句,表示执行C#代码。

item变量是在C#代码中声明的,所以要想调用C#变量item的值必须使用@item。

混编代码:

浏览器截图:

3、前台利用foreach嵌套if循环输出(连续)

当前台的C#代码有多行时,如果这些代码是连续的中间没有HTML代码隔断,那只需要开头的一个@符号即可。

混编代码:

浏览器截图:

4、前台利用foreach嵌套if循环输出(不连续)

当前台的C#代码有多行时,如果这些代码是不连续的,中间被HTML代码隔断,那HTML代码之后的被隔断的C#代码开头需要加上@符号。

Razor用来隐式鉴别一个代码段什么时候结束的方法是寻找代表内容块开始的标记或元素内容。例如,在上面的例子中Razor自动地把if和else中的

< label>< /label>模块当作一个HTML内容块,因为它看到开始的< label>标记序列并且知道这在C#中是无效的。

然而不是所有的内容块都以标记元开始,在这种情况下Razor解析器不能隐式检测出内容块,这就需要Razor通过在代码块中使用“@:字符序列”来显式指明内容块的开始。

如果当item==”北京”时输出“item (首都)”这个字符序列,其他情况输出“item”,不能依靠简单地去掉@来实现:

因为C#代码不支持这种写法,代码如下:

if(item == "北京")

{

    item (首都)

}

else

{

    item

}

1

2

3

4

5

6

7

8

这时就用到@:了,如果想输出“item (首都)”,就写成“@:item (首都)”,此时@:之后的“item (首都)”被当做普通HTML代码处理。

这种写法之所以成立,是因为HTML代码支持这种写法,代码如下:

<div>

item (首都)

</div>

1

2

3

混编代码:

浏览器截图:

5、前台利用foreach嵌套if循环输出(不连续)

前台C#语句中声明的变量,也可以被前台调用。

如果既想输出item的值,又想输出一些普通字符串,那“@:字符序列”同样可以满足你的要求。

混编代码:

浏览器截图:

6、@:输出多行内容

在没有被外部HTML元素包装的情况下,如果需要输出多行内容时,可以使用多个“@:字符序列”来实现。

混编代码:

浏览器截图:

7、使用< text>元素显式标识内容

< text>标签是一个Razor特殊处理的元素。Razor将< text>块的内部内容视为内容块,不呈现包含那些内容的< text>标签,这使呈现没有被HTML元素包装的多行内容块更方便。当前台代码中有多个“@:字符序列”时,可用< text>< /text>来替换。

混编代码:

浏览器截图:

js代码与C#代码混编

1、js中嵌套C#的if结构

混编代码:

浏览器截图:

2、js中自有的if结构

当if语句的判断条件用到字符串类型的C#变量的值时,需要额外加上”“,否则C#变量的值会被当做js中的变量名,从而引发错误。

js中用到bool类型的C#变量的值时,也需要额外加上”“,否则报错:True is not defined或False is not defined,因此推断js中用到char、DateTime等其他类型的C#变量的值时,均需要额外加上”“,先把C#变量的值变为普通字符串,然后才能进行其他操作。int、float不需要额外加上”“。

不加”“的混编代码:

不加”“的浏览器截图:

加”“的混编代码:

加”“的浏览器截图:

3、js中嵌套C#的foreach(){ if(){ } }结构

混编代码:

浏览器截图:

4、js中自有的foreach(){ if(){ } }结构

js不能识别List< string>类型的数据,可以使用json数组来代替List< string>,前台对json数组进行循环操作即可。js中要用for(var index in array){ }来做循环操作,此处的index指的是数组索引值。

后台代码如下:

var (@Model.CityListJson);的作用等价于本方法中注释掉的三行代码的作用,前台代码如下:

浏览器截图如下:

点赞 4

————————————————

版权声明:本文为CSDN博主「changuncle」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/xiaouncle/article/details/53505792