采用后端代码方式实现对Html元素封装与输出
liuian 2024-12-10 18:06 43 浏览
概述
在以浏览器为核心的应用软件开发中,Html元素是绕不开的一个部分,本文采用C#代码对Html元素来进行封装,用于完成对Html元素的输出。其他语言也是一样的实现逻辑!
技术点说明
1、html标签类似xml结构 是标签名 + 属性 + 内部Html构成
2、Html标签三种类型 双标签、单标签和自闭合标签三种组成
双标签
<p>内容</p>单标签
<br>自闭合标签
<input name="UserName" type="text" />单标签与自闭合标签其实是一样的,通常我们会将比如<br>写成<br />
标签格式
<标签名 属性数组> 内部Html</标签名>
例:
<p id="a1" class="classname" 其他属性1="值"> 内部html</p>
或者
<input id="a1" name="a1" class="classname" 其他属性1="值" />
代码定义
比如 HtmlElemHelper
如下:
说明:
1、Style 值又是由KeyValue结构来完成的,设置Style的时候,将key与value存储起来最后合并最终的属性
2、Class 是由空格分隔出来的字符串组成的,也在最后合并
3、如果是单标签或者自闭标签是没有innerHtml的,只有双标签才有InnerHtml
最终形成Html的过程
无论是哪一种标签类型,都有属性
1、先拼接Style与class 加入到最终的属性
2、合并属性形成列表 存放到标签属性中,使用空格分隔
3、如果是双标签 将转入InnerHtml
4、最后将这几部分合并成最终的html标签
示例
//定义父级编码的Id
HtmlElemHelper htmlParentElemHelper = new HtmlElemHelper("div");
string pId = "";
string curId = GetAttrValue("id", "");
if (!string.IsNullOrEmpty(curId))
{
htmlParentElemHelper.SetAttr("id", pId);
}
htmlParentElemHelper.SetAttr("class", "AuCtrl AuCtrlCheckBoxGroup");
// 定义父级容器
StringBuilder sbOption = new StringBuilder();
if (Items != null && Items.Count > 0)
{
if (string.IsNullOrEmpty(Values))
{
Values = "";
}
String[] arrValue = Values.Split(",");
foreach (TextValueItem textValueItem in Items)
{
string checkedInfo = "";
foreach (string s in arrValue)
{
if (s.Equals(textValueItem.Value))
{
checkedInfo = " checked=\"checked\"";
break;
}
}
string item = #34;<input type=\"checkbox\" name=\"{Name}\" value=\"{textValueItem.Value}\" {checkedInfo} title=\"{textValueItem.Text}\" />";
sbOption.AppendLine(item);
}
}
//设置内部html
htmlParentElemHelper.SetInnerHtml(sbOption.ToString());
//
Html = htmlParentElemHelper.GetHtml();说明:
这个用了两次HtmlElemHelper,一个元素的html是另外一个元素的InnerHtml
共创、共享、共赢!
相关推荐
- qq下载2025手机版(qq下载2020手机版)
-
目前来看的话java版的QQ还是可以用的。.我们需要用那种比较老式的塞班系统手机才能下载安装使用,就目前的时代使用它的意义就看我们自己怎么理解了,不过社会在进步,科技也在发展,要想更强时代的潮流,万物...
- nod32(NOD32手机版)
-
nod32是斯洛伐克共和国,简称斯洛伐克,是中欧的一个内陆国家。打开nod32,在主窗口右上角有一个设置按钮,单击它就会出现一个下拉菜单,再点击用户名和密码设置即可出现你第一次申请时的用户名和密码1...
- 分盘c盘分多大合适(分区c盘一般多大)
-
如果硬盘大,有一千个G,可以把硬盘分成4个盘,c盘,D盘,E盘,F盘,C盘大点,分300个G,D盘,E盘,F盘各分230个G,因为很多操作系统都在c盘,c盘有足够的空间,电脑反应才快。100G。按照安...
- 绘图显卡天梯图(绘图显卡性能排行)
-
NVIDIA是Quadro系列和ATI是FireGL系列都属于专业绘图显卡。这里分别介绍下其中一款产品的参数:NvidiaQuadro4000参数:显存类型:GDDR5;显存容量:2048M...
- 哪个网站的win7系统好用(哪个网站的win7系统好用一点)
-
靠谱,系统之家的系统装好后不需要激活,也不要钱。只是系统之家的所有东西,系统也好,软件也好。都有强有力的写在系统底层的顽固病毒,只要碰过系统之家就永远杀不干净。当然了,永远关不掉的广告弹窗也是基本操作...
- 升级win10的最低配置(电脑升级win10的最低配置)
-
1最低配置是1GHz的处理器、1GB的内存和16GB的硬盘空间2因为升级操作需要一定的计算机资源,若电脑配置过低,升级可能会出现卡顿、崩溃等问题。因此微软推荐至少1GHz的处理器、1GB的内存和1...
- 手机上怎样鉴定u盘容量(手机上怎样鉴定u盘容量呢)
-
手机想要检测u盘的真实内存,可以首先在手机上下载一个u盘管理软件。下载完毕之后,就利用转换器连接u盘在手机的充电口。手机读取之后就可以出现现有的内存,将它导入u盘管理软件。就可以读取深层次的真实内存。...
- 电脑桌面图标隐藏了怎么恢复
-
首先长按手机应用界面空白处,在弹出的菜单中点击隐藏图标按钮,接着输入密码,可以看到被隐藏的应用,长按要恢复的应用,将它拖动到桌面即可。1、双击打开此电脑;2、点击【查看】,勾选【隐藏的项目】;3、右键...
-
- 手机如何还原到原来的系统(手机怎样恢复到原系统)
-
可通过恢复出厂设置恢复旧版本。以oppo手机为例,具体如下:1、首先,打开手机桌面上的“设置”图标。2、点击进入之后,在跳转出来的页面中,选择“常规”页面下的“更多”选项。3、进入“更多”之后,点击选项最上面的“恢复出厂设置”选项。4、在恢...
-
2025-11-09 20:55 liuian
- psd格式怎么编辑(psd格式怎么修改图片)
-
PSD格式的图像,可以使用Photoshop来打开。 PSD--PhotoshopDocument(PSD),是著名的Adobe公司的图像处理软件Photoshop的专用格式。这种格式可以存储P...
- xp系统恢复出厂设置步骤图解
-
电脑xp系统一键还原具体操作方法如下:1.在电脑里打开一键GHOST程序2.会看到有以前备份过的系统文件信息,默认选项是(一键恢复系统)项,点击(恢复)。3.点击(恢复)后弹出对话框,提示恢复系统必须...
- 联想哪款笔记本电脑最好(联想笔记本那个款好)
-
联想笔记本电脑有4个系列,分别是:1、昭阳笔记本电脑针对行业客户设计的高品质笔记本电脑。高端、高性能的同时具备多重可信赖的安全保护方案。昭阳系列针对行业客户提供按需定制服务。2、旭日笔记本电脑联想旭日...
- 测速网速在线测试(在线测速网络速度)
-
是指通过特定的软件或网站,对用户的网络连接速度进行测试和评估。这种测试通常包括上传速度、下载速度、延迟时间等指标,帮助用户了解自己网络连接的性能和稳定性。常见的网速在线测试网站或软件有Speedtes...
- win7旗舰精简版(win7精简版系统怎么样)
-
Windows7SP1旗舰版64位超级极度精简封装版,属于深度精简(1G ESD版),基于Windows7SP1旗舰版进行精简优化封装,集成最新安全补丁,特别适合高主频单核、低主频...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
