Razor与HTML混合输出陷阱与技巧

3,Razor与HTML混合输出陷阱与技巧

属性名称误判
有时候我们必须让html内容与razor语句紧接在一起,
eg:      您好,a先生
假设变量名称为ViewBag.Name,
您好,@ViewBag.Name 先生  //这样输出就只有”您好,”,后面的Name 先生被当做是viewbag的属性去了,所以如果要解决这个问题就是加个小括号便好,如 “您好,(@ViewBag.Name )先生”
还有一个办法就是用一个html标签包起来,如“您好,<标签>@ViewBag.Name</标签>先生”,或者将先生用html标签包起来,都是可以的。
未预期的额外属性
如果想要输出一个c#的命名空间,而输出的部分北荣要变成razor变量,类别是System.Web.Mvc.Controller
eg:
@{
ViewBag.MvcNameSpace="System.Web.Mvc";
}
类别是@ViewBag.MvcNameSpace.Controller
结果输出会引发错误,string未包含controller的定义,原因在于razor解析@ViewBag.MvcNameSpace时把Controller这段当做是@ViewBag.MvcNameSpace的一个Controller属性,因此解析错误,遇到这种情况解决办法也是加个小括号,eg: @(ViewBag.MvcNameSpace).Controller,就会输出“System.Web.Mvc”
输出Email地址与@跳脱子元
<超链接a  href="aaabbb@qq.com">aaa</超链接a>,也许有人会说@在razor里是个关键字,这里应该放两个@符号,其实不用,razor会自动判断前后文,只要@的前面和后面都有文字的话,预设这次@就会停用razor语法解析
<超链接a  href="aaabbb@qq.com">aaa</超链接a>如果要将aaa的位置替换为变量
@{
ViewBag.BlogID="aaa";
}
<超链接a  href="@(ViewBag.BlogID)bbb@qq.com">aaa</超链接a>,也只要加个小括号就可以,
输出未经htmlEncode的字串
预设使用razor语法输出变量,所有内容预设都会被HTML编码为HtmlEncode,这是为了保护网页不致遭受跨网站脚本攻击,有了这个预设值,能确保新手写出不安全代码
eg:
@{
ViewBag.Description="<标签 style='font-size:12px;'>描述文字</标签>";
}
@ViewBag.Description
最后输出的结果中会是htmlencode过的版本:大于号小于号双引号都变成了&加一些字母的形式,解决办法就是利用@Html.Raw辅助方法帮助我们输出内容 @Html.Raw(ViewBag.Description)这样就会原封不动的输出我们想要的样子。

转载于:https://www.cnblogs.com/jinhaoObject/p/4597670.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/288562.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

“威胁情报”在手,反黑客终于有地图了!

安全是一场攻防战&#xff0c;那么&#xff0c;如今这样的攻防战发展到了什么level了呢&#xff1f;日前&#xff0c;安全领域的大神们进行了一场闭门研讨 。大神们表示&#xff0c;如今要想保证自己的安全&#xff0c;你不仅需要武器&#xff0c;还需要侦察兵&#xff0c;需要…

winform插入时间类型数据到oracle数据库,winform操作访问Oracle 10g数据库,并自动填充到DataGridView...

使用oracle的ODP.NET是官方推荐&#xff0c;而且相对简单的方法。官方指导文档&#xff1a;http://www.oracle.com/technetwork/cn/testcontent/o23odp-084525-zhs.htmlapp.configForm1.aspx.csusing System;using System.Collections.Generic;using System.ComponentModel;usi…

print的describe的展示全部数据_大数据项目中的QA需要迎接新的挑战

根据IDC全球半年度大数据和分析支出指南的最新预测&#xff0c;到2022年全球大数据和业务分析解决方案的收入将达到2600亿美元。在大数据和业务分析解决方案上投资增长最快的行业包括银行&#xff08;复合年增长率13.3%&#xff09;、医疗、保险、证券和投资服务、电信&#xf…

Enum枚举类型实战总结,保证有用!

一般在我们开发时如果能使用枚举罗列的&#xff0c;一般都会定义一个枚举类型。将枚举类型作为方法的参数&#xff0c;可以方便的进行调用&#xff0c;给我们带来不少的便利&#xff0c;当然有时候它还不如直接用一个int类型带来&#xff0c;带来一定灵活性。但只要能满足业务咱…

C/C++笔试面试题目(2021最新版)

1、main函数执行完毕后,是否可能会再执行一段代码? 答案:可以,可用_onexit 注册一个函数,它会在main()函数之后执行。 2、一个父类写了一个virtual 函数,如果子类覆盖它的函数不加virtual ,也能实现多态? 在子类的空间里,有没有父类的这个函数,或者父类的私有变量?…

sql 子查询(mysql)

子查询&#xff1a;一个查询嵌套在另一个查询当中&#xff1b;又叫内部查询。 子查询 可以分为&#xff1a; 单行单列&#xff08;就是一个值&#xff09; 单行多列&#xff08;就是有一行&#xff0c;这一行有很多不同列数据&#xff09; 多行单列&#xff08;同一列不同的…

学习笔记-第四周-心得体会

第五章《控制电动机》预习 步进电机的原理在课堂上已经进行了初步介绍。实际中在低端应用上步进电机使用较多&#xff0c;可能是出于原理简单&#xff0c;控制方便等原因&#xff0c;带来的问题可能是精度较差&#xff0c;不适宜用于精密控制。除去常见的伺服电机和步进电机&am…

linux c之通过popen执行shell命令

1 popen介绍 我是在ubuntu上面进行man popen的,解释如下 这个函数通过创建一个管道通过fork一个进程,然后执行一个command,因为在管道中,所以数据流是单向的,然后type一般只能是读“r”或者写“w”,返回值在IO流里面,用了popen之后我们要记得用pclose函数。 2 使用 #inc…

python socket之udp说明

UDP方式UDP 号称无连接传输&#xff0c;全然没有TCP那么复杂&#xff0c;三次握手&#xff0c;错误重传之类的机制都没有&#xff0c;发的只管发&#xff0c;收得只管收&#xff0c;收到没有&#xff1f;不知道&#xff0c;顺序不对怎么办&#xff1f;不管&#xff01;就是 这样…

oracle内外链接混合用,混合在一起通过连接,内部连接和总结与Oracle

这里是我的设置&#xff1a;我有2个表分别被称为“任务”和“时间表” “任务”表是递归的&#xff0c;这样每个任务可以有多个子任务。每个时间表都与一个任务相关联(不一定是“根”任务)&#xff0c;并包含在其上工作的小时数。实施例&#xff1a;任务ID&#xff1a;1 |名称&…

指针,指针函数,指针数组的区别

1、指针 #include<iostream> using namespace std;int main() {int a2;int *p;p&a;printf("%d\n",p);printf("%d\n",*p);return 0; }2、指针函数 #include<iostream> using namespace std;int *p(int a) {int *P;P&a;return P; } int …

python组件介绍_python 中的爬虫· scrapy框架 重要的组件的介绍

一 。 去重的规则组件去重数据&#xff0c;中通过set() 去重的&#xff0c; 留下的数据存在redis 中&#xff0c;找到这个类 &#xff1a; from scrapy.dupefilter import RFPDupeFiltera. 爬虫中yield Request(...dont_filterFalse)b. 类from scrapy.dupefilter import Base…

用java调用.net的wcf其实还是很简单的

前些天和我们的一个邮件服务商对接&#xff0c;双方需要进行一些通讯&#xff0c;对方是java团队&#xff0c;而作为.net团队的我们&#xff0c;只能公布出去的是一个wcf的basicbinding&#xff0c;想不 到问题来了&#xff0c;对方不知道怎么去调用这个basic&#xff0c;可能他…

php 使用PDO,防止sql注入 简单说明

PDO&#xff1a;php5 假如以下是一个简单的登录处理&#xff1a; 使用PDO连接mysql首先&#xff1a; 新建数据库 new PDO("mysql:hostlocalhost;dbnametest","root","root"); host:服务器 dbname:数据库名 后面两个分别是帐号和密码 默认…

DbTool 2.0.0 Released

DbTool 2.0.0 ReleasedIntroDbTool 一个支持 DbFirst、ModelFirst 和 CodeFirst 的数据库小工具。DbFirst 是根据数据库中的表信息生成代码中的 Model&#xff0c;以及生成数据表结构文档ModelFirst 是根据数据表信息或者数据表结构文档生成创建数据库的脚本CodeFirst 是指根据…

[蓝桥杯] 蚂蚁感冒

[蓝桥杯] 蚂蚁感冒 峰值内存消耗 < 256M  CPU消耗 < 1000ms 【题目描述 - Problem Description】 长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左&#xff0c;有的朝右。 每只蚂蚁都只能沿着杆子向前爬&#xff0c;速度是1厘米/秒。 当两只蚂蚁碰面时&#xff0…

Source Insight之Relation Window Properties配置和一些快捷键

1 Source Insight之Relation Window Properties配置 我们先点击source Insight的这个地方 然后鼠标右键&#xff0c;点击Relation Window Properties&#xff0c;配置如下 2 快捷键 目前就我知道的 1&#xff09;按亮和按熄这个变量 shift F8 2&#xff09;跳转到具体一行…

ArcGIS 10.2 Calculate Value(Data Management) 工具的使用

1、概述 Calculate Value tool returns a value based on a specified Python expression. 计算值工具返回一个基于特定Python表达式的值。 工具位置:ToolBox→Data Management Tools→General→Calculate Value 2、注意事项 (1)该工具只能用于MoudleBuilder,而不能用于Py…

omnicppcomplete php,VIM 常用法 (三)

这里描述常用的插件。1. NERD tree快捷键&#xff1a;o 在已有窗口中打开文件&#xff0c;并跳到该窗口go 在已有窗口中打开目录或文件&#xff0c;但不跳到该窗口i/s 在split/vsplit的新窗口打开文件&#xff0c;并跳到该窗口gi/si 在split/vslpit的新窗口打开文件&#xff0c…

android:versionCode和android:versionName 用途

Android的版本可以在androidmainfest.xml中定义&#xff0c;主要有android:versionCode和android:versionNameandroid:versionCode:主要是用于版本升级所用&#xff0c;是INT类型的&#xff0c;第一个版本定义为1&#xff0c;以后递增&#xff0c;这样只要判断该值就能确定是否…