下面就和大家分享下我在asp.net官网看到的资料,学习到的点语法。
1.通过使用@符号,可以直接在html页面中写C#或者VB代码:
data:image/s3,"s3://crabby-images/3aebc/3aebc256f896258ee31e52c242d55bf3690d3d66" alt=""
运行后:
data:image/s3,"s3://crabby-images/bc4fe/bc4fe0e2e4273b590db558bed5d587ad3c7b2dce" alt=""
2.页面中的C#或者VB代码都放在大括号中。
data:image/s3,"s3://crabby-images/7ba6b/7ba6b559687fbb872699fe25e047601aee1087d5" alt=""
运行后:
data:image/s3,"s3://crabby-images/4c7d5/4c7d5b0287179e54f509744cfb3e6d56497a8816" alt=""
3.每一行代码通过分号来结束:
data:image/s3,"s3://crabby-images/4c8fe/4c8fe9dc292487458802c1fdd0918fe68599507e" alt=""
运行后:
data:image/s3,"s3://crabby-images/a692b/a692b332165705cd1fc15b8b3e6fb01a614cda6f" alt=""
4.在页面中输出特殊字符,双引号和斜杠:
data:image/s3,"s3://crabby-images/f3471/f347185ab7a0773d5c4ee0014f34cac87cbcb06a" alt=""
运行效果:
data:image/s3,"s3://crabby-images/4e3e0/4e3e01762f6baed359db72925de9f5c935ff4b7c" alt=""
5.通过Request属性得到当前页面的url,RequestType等。
data:image/s3,"s3://crabby-images/d899b/d899bb97b8e021cbd7c8066d52058b992b883a4b" alt=""
运行结果:
data:image/s3,"s3://crabby-images/db1c1/db1c1974e410ecebb8387a6b80d9bdd77ab0354a" alt=""
6.通过if---else:
场景是,我们通过判断当前浏览器是否向服务器端post数据,如果post则提示你点击了Post按钮。
data:image/s3,"s3://crabby-images/70d01/70d015a19071b9db88eaabed8e9f535b855fe095" alt=""
运行后:
data:image/s3,"s3://crabby-images/93b9f/93b9f9536890159f9e068b47e6d6e9853f5e5da8" alt=""
- 爱因斯坦小脑 2011-05-02 14:55
成都创新互联主要从事网站制作、
成都网站制作、网页设计、企业做网站、公司建网站等业务。立足成都服务同心,十多年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575
下面是一个完整的例子:
data:image/s3,"s3://crabby-images/f76bf/f76bf293ffbafcc58ef1d1f220dd66fa99ea4962" alt=""
当点击submit按钮后,@totalMessage将会是输入text1和text2的和。
data:image/s3,"s3://crabby-images/1644c/1644cd588d4348285c9eb5e94e1030bbef7d7453" alt=""
Razor中还有自己的类型转化:
data:image/s3,"s3://crabby-images/f1716/f17167c67a3946f734b0e64b369044776e56e4b1" alt=""
另外就是Razor中的注释,有两种方式-:
data:image/s3,"s3://crabby-images/cc90e/cc90ec4624ef1b278734f712f977f7eeccd0d503" alt=""
- 爱因斯坦小脑 2011-05-02 15:04
和Webform引擎相似,Razor语法也允许让一些服务器端的代码嵌入到web页面。客户端的代码主要是一些html和css,javascript等。当页面中有服务器端需要解析的代码时,这些Razor语法的代码会动态的被编译成HTML标记,并返回到客户端。
Web form引擎的文件必须是aspx或者ascx后缀的,Razor的文件时cshtml或者是vbhtml后缀。服务器端是通过文件后缀来决定当前的文件是否使用了Razor语法。
Razor也是在Asp.net基础上的一种新的语言,它和asp.net以及.net framework平台的关系如下:
data:image/s3,"s3://crabby-images/64628/646280f8a1dd7b50cb07324525f80de439a796af" alt=""
所以如果你的网站现在使用的是Asp.net那么你就可以现在开始不适用.aspx和ascx页面而使用.cshtml或者vbhtml页面,我只知道在asp.net mvc中只要把对应的试图引擎给注册下酒行了。 对于传统的asp.net网站就不大了解如何同时使用几个试图引擎了。
1.更加简洁的让text,html和代码集合到一起
例子:
data:image/s3,"s3://crabby-images/70790/707908a4b5524299a8da3afd434b31d398786275" alt=""
上面是使用Razor引擎的代码,如果使用webform试图引擎,你需要使用<% %>标记来把代码和html集合到一起,但从把代码和html集合到一起来看,@符合也就是比<%%>少写一个标记,但是如果代码行数多了以及对于if else的判断使用的花括号都需要<%%>标记,你就会感觉的Razor真的是简洁了不少。
运行效果:
data:image/s3,"s3://crabby-images/4d3fe/4d3fe85d4d838cbd88cfcb4b703217be0a92f304" alt=""
2.@: 的使用和
标记的使用:
@: 用来输出文本或者是那些未能找到匹配的Html标记的标记符。如果是单行使用@:,但是对于多行代码显示,就可以使用text标签来替代@:了。
例子:
data:image/s3,"s3://crabby-images/ce114/ce1141ebb20e1ea7e8da3a6bebc0602547e0ef4a" alt=""
这个我运行的结果好像和预期的不一样。。。。
使用标记也是一样的效果,难道是RTM版本把这个功能去掉了??、???
3.变量赋值时换行的问题。
data:image/s3,"s3://crabby-images/da366/da3663d38712e63dcb0ae2ef37f5fef1f4b534cf" alt=""
你可以一行内为变量赋值,或者是在其它行开始时为变量赋值,或者是使用转义符号@,上面例子的1,2,3种情况是正确的赋值,但是方括号包住的会直接报错。
4.变量的类型:
data:image/s3,"s3://crabby-images/c86e8/c86e84468ca2f7633039e906b343edd72228644a" alt=""
Razor中的数据类型和C#中的差不多,很多C#的变量类型以及声明变量的方式,都可以在Razor中看到。。。。。比如上面的stirng name=”Joe”; int count=5;等。
- 爱因斯坦小脑 2011-05-02 15:06
Raozr中文件目录的获取:
和webform引擎相似,例子:
data:image/s3,"s3://crabby-images/fc706/fc706839342202d5a38f41c0b00bd4508c4afa22" alt=""
运行效果:
data:image/s3,"s3://crabby-images/7be0f/7be0f11793d79ae10366ea6c5c83861533f8c05e" alt=""
5.条件判断和循环的使用
条件判断有if, switch等,
先看使用if条件判断的例子:
data:image/s3,"s3://crabby-images/9510a/9510af273470dd24bc7b7ccfa36a8e85c3d8aea0" alt=""
如果是在C#中,上面的if(showToday)后面不需要是用大括号也可以正常显示,但是在Razor中,如果不加这个大括号,你就杯具了。
使用if…else的例子:
data:image/s3,"s3://crabby-images/5e40e/5e40e35fe6dbff9745b0fd99b9fe13d8cbcce1e4" alt=""
上面的例子中我们使用了if---else,这个和C#中的相同,如果你仔细看发现下面有个@:或者是我注释掉的标记,它们的作用是在Razor代码中能够输出文本。而不需要输出html。
switch条件判断例子:
data:image/s3,"s3://crabby-images/04fd2/04fd25884ed60bbb9e1c1635ccac2d57d644a350" alt=""
运行结果:
data:image/s3,"s3://crabby-images/44a45/44a4502962ccfe6785b6fec05ea320552b0990a7" alt=""
循环就不用说了for,foreach,以及while。
for循环:
data:image/s3,"s3://crabby-images/6efc5/6efc5ee5e3867c2e6e1289e11472eb71abd4753e" alt=""
data:image/s3,"s3://crabby-images/caaef/caaef28fb99d583f6c498f7c2cee74f3dc4835a4" alt=""
foreach的使用:
data:image/s3,"s3://crabby-images/a47e2/a47e2c05c99ef05d20c61cd2f1778686ecc3b210" alt=""
- 爱因斯坦小脑 2011-05-02 15:08
6.超链接的使用。
在Razor中有个方法是Href,它主要是用来在img标签和link以及a标签中得到对应的文件的完全url而设计的。
例如:
data:image/s3,"s3://crabby-images/1fe78/1fe78b6acf2f24f0fcc33db5c4f3b13fd22de957" alt=""
运行:
除了这些语法,在Razor中也可以使用System.Generic.Collection中的那些容器。比如Dictionary.
也支持直接在Razor代码中捕获异常。
当前文章:Razor视图引擎语法学习(二)-创新互联
文章URL:http://mswzjz.cn/article/dhhscp.html