百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

采用后端代码方式实现对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...

qq人工客服入口(qq人工客服详细联系方法)
  • qq人工客服入口(qq人工客服详细联系方法)
  • qq人工客服入口(qq人工客服详细联系方法)
  • qq人工客服入口(qq人工客服详细联系方法)
  • qq人工客服入口(qq人工客服详细联系方法)
手机上怎样鉴定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旗舰版进行精简优化封装,集成最新安全补丁,特别适合高主频单核、低主频...