很多时候。我们需要在后台用C#代码添加html标签。而不是在html源码中添加。

比如在html源码中简单的一个input 标签

 <input type="type" name="name" value=" " />

那我们在后台用C#代码怎么写呢。那么就要用到HtmlInputText类 命名空间  System.Web.UI.HtmlControls.HtmlInputText

               //定义了一个文本框 对应html中 input type="text"
System.Web.UI.HtmlControls.HtmlInputText text = new System.Web.UI.HtmlControls.HtmlInputText("text"); //text就是文本框类型 如果是button则是一个按钮 即 type="button" text.Attributes.Add("name", "aa"); //定义属性 也可以是自定义属性
text.Style.Add(HtmlTextWriterStyle.BorderStyle, "none"); //定义样式
text.Attributes.Add("class", "Wdate");//添加类样式
text.Style.Add("Cursor", "pointer"); //跟下面效果一样
text.Style.Add(HtmlTextWriterStyle.Cursor, "pointer");

既然创建一个button标签也是同样的方法 也许你会问那如果我要创建一个div span标签呢。

记住HtmlInputText只是提供了由.netFramework提供的ui 并不包含诸如 div span的ui

所以你得用HtmlGenericControl类: 定义不由特定的 .NET Framework 类表示的所有 HTML 服务器控件元素的方法、属性和事件。那我们一起来看看怎么定义一个span

               //创建一个span标签
HtmlGenericControl span2 = new HtmlGenericControl("span"); //属性
span2.Attributes.Add("title", "选择型号");
span2.Style.Add(HtmlTextWriterStyle.Width, "20px"); //按钮的高度 //Page.Controls.Add(span2); //添加到页面
          
        //但我这里介绍我用的模版添加标签(将在下面介绍)。因为是给aspxgridview动态添加模版列 ,里面需要text标签。

从两段代码可以看出。除了创建标签的方式不同 。添加属性或者样式都是相同的

因为我这里是添加模版,这仅仅是添加了标签。因为你并没有添加到控件集合。并不会输出到页面 。接下来我们定义一个类 继承ITemplate(模版)

比如:

  class Templates : ITemplate
{
//实现接口
public void InstantiateIn(Control container)
{
//我这里演示的是 。先添加一个text文本框标签 然后把text添加到span1标签中 最后在把span1标签添加到span2中 然后把span2添加到控件容器中。
System.Web.UI.HtmlControls.HtmlInputText text = new System.Web.UI.HtmlControls.HtmlInputText("text"); text.Attributes.Add("id", "txt");
text.Style.Add(HtmlTextWriterStyle.BorderStyle, "none"); HtmlGenericControl span1 = new HtmlGenericControl("span");
span1.Attributes.Add("class", "ContSpan"); //把input添加到span中
span1.Controls.Add(text); //创建第二个span标签
HtmlGenericControl span2 = new HtmlGenericControl("span"); //把span2添加到input后面 这里的 1 表示span2在控件数组中的索引 因为先添加了一个text索引为0
span1.Controls.AddAt(, span2); container.Controls.Add(span1); //最后把整个控件添加到容器中 当然你完全可以放在指定的位置 比如哪个id的里面。 }
}

需要用到模版的就实例化Templates类。就可以添加控件到页面了。下面是添加的核心代码

          //实例化一列
GridViewDataColumn gdc = new GridViewDataColumn(dc.ToString(), item.Ctitle); //列的数据 列的标题 if (item.Ctitle == "型号")
{
Templates t = new Templates(item.Ctitle, "both", item.Etitle);
gdc.DataItemTemplate = t;//这里就是给 数据模版(DataItemTemplate ) 添加标签 }
else
{
Templates tem = new Templates(item.Ctitle, "text", item.Etitle);
gdc.DataItemTemplate = tem;
}

结果:

aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMoAAAAkCAIAAABHSTINAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAEg0lEQVR4nO2bwVMbdRTH3/vtJiFpkYSkwHYgWooMpFgZ0Rl1DNZ66KGeOoNjLz0hf1PBA1x6r9NxRofqhYtyIRWtbROlTKWSJoGEBEiW7P48pLMTdje7S5IFzbzPKfntey+/yfvOe7+32WAqlYLjrKysxONxIIiWYWe9AaKTIXkRLkLyIlyE5EW4CMmLcBFcXFw86z0QHQtyznVLiURicnLyTHZDdBjUHAkXEU1XFxYWTnkfxH+Wubm5pn3N5dViUKJjaLHQUHMkXKRh9eoMEE1mF6IVfk7+svzrj5FAmHMADgyEnWLhvZHJG1PXEVFnfDJ5WWSr/pLuY3QumqWFmfNoTvZGtIviYfHh+sPZz2elYL+2WDgozn+3GIuORvuGdPYnkFctfw6z2EgcbTQzujgUItE0pXKp91yvFOz/9tn9zcImCizkD90e/+qSNLyzt9O8vDRVWSisll2HSa0ZW6iqPpqpmXapUXUk2kh+P58upLOFbOWoonAlmUslM0kQIdIdqagV+Uh+md4K+M4Fzwf7QhHNy5G8dHXLqDDTHDeKYwwIhrKki2Zd5KwrH9E6q3+tfr/+g9QjqUfK+MVxAZlP9DEPEwShS+wCwOH+6KPko5eF3Ve72anRd298cK3maCOv+hJiVBiYJV4z0K3XY9sTddEsBESF6hRY/n35609npaCkgCoAOzg6UBTl9TUOpXLpo9jUh7EpBMzvF+/eX3IqL2N2NVXV59X5mcwY3HS9Plqj4LZFi5TXLs77uqWg9OCPB0+2nzAP48gzhxmf4EMBS3Lp3uN7Ho9HBnmoe3Bm+Mv+0IDm6Kg5Oml8OpqwsRgJdcbWytM6r+0GCIfUvsoX+RepdAp8gCJ6vV5REBmwKq9u7G0AAxlkjpwD51zRHE9838uikDTqpPUttd7L4mwOx/tj/VlN1zfBrv8S7QIRgQEiIiACAgAHjq8XAHktDce+d3t5Wcz/tv0LGs9xprcYTEcH27bbRHElmqAv0DfYM8i8jDNekAtVtQoCiCiG/WFBFGQuX/BfQGCMCZpLM82xhvVsCHady6F6jCXQ4U6INlIs7+X2c7eu3vpi4iZwODg6XEosJXeTAgghf+jOlTuRQBgZiiAeVsqZ/CvNsZ0/ChlF06iqORkFtAhgJ0GqXm4TH5u++9N8NPyWWlWjvYOfTVwTBZED58ABoTcQWv/z2W8bj0WP95/M9lh0RHN0et/LiZlultRemFYg27ORsbw5uW1L2nKD6dHpmBTbym1lC9nE88T0lbisyGpVVUGVqzIH/vTvZNDXNTw4cv2djy9GTjI5Ojwjm2pL99Y0lO3iidzpRO8Ske5IpDuynd9+mk4KKETfiCqqwgTs9Ye9zOvzdl0aGLp6eULn1eFPTJDa2ovf698p5XKl3ZnYjAoqADBgh5XyZvr5+wZtQcfLi2gvPYGeT8bi88vfDPQMAEfOkQHLFLJvS8Nv9keN9uZ/5VhdXT2V3RL/A1p5bpn+KUS4CD0MTbgIyYtwEVxbWzvrPRAdC529CBeh5ki4CMmLcJF/AXJkoWjT72pjAAAAAElFTkSuQmCC" alt="" />

大体思路就是这样的。也许我的代码还不完善。

如果你还有这样的需求 :在后台需要遍历页面上的控件 (服务器控件这里就不说) 主要是input标签 div span等

都指定页面的标签类型很多。我们遍历控件时都要判断是否是自己需要的类型标签 。故 要转换。其实就是个判断。知道判断就容易了

从上面的列子可以看出。创建一个div用到HtmlGenericControl 类  所以你遍历div时。只要判断Control是否可以转换为HtmlGenericControl

当然你得要知道什么时候用HtmlGenericControl 。如果是遍历页面的a标签那自然是转换为HtmlAnchor 想必你应该懂

比如我页面有这样一段代码 想要获取 div id="mb"中所有的a标签 的id值和自定义属性的menu的值 记住 后台要访问input标签 必须加上runat="server"

        <div id="mb" runat="server" style="padding:5px;margin-top:5px;" class="ui-widget-header">
<a runat="server" href="javascript:void(0)" id="N8000" plain="false" class="easyui-menubutton" disabled="false" menu="#mm1" iconCls="icon-gzt">1</a>
<a runat="server" href="javascript:void(0)" id="N5000" plain="false" class="easyui-menubutton" menu="#mm2" iconCls="icon-xwbj" menuid="N5000">2</a>
<a runat="server" href="javascript:void(0)" id="N1000" plain="false" class="easyui-menubutton" menu="#mm3" iconCls="icon-kcgl" menuid="N1000">3</a>
<a runat="server" href="javascript:void(0)" id="N3000" plain="false" class="easyui-menubutton" menu="#mm4" iconCls="icon-cggl" menuid="N3000">4</a>
<a runat="server" href="javascript:void(0)" id="N2000" plain="false" class="easyui-menubutton" menu="#mm5" iconCls="icon-xsgl" menuid="N2000">5</a>
<a runat="server" href="javascript:void(0)" id="N4000" plain="false" class="easyui-menubutton" menu="#mm6" iconCls="icon-yfys" menuid="N4000">6</a>
<a runat="server" href="javascript:void(0)" id="N6000" plain="false" class="easyui-menubutton" menu="#mm7" iconCls="icon-xjyh" menuid="N6000">7</a>
<a runat="server" href="javascript:void(0)" id="mb8" plain="false" class="easyui-menubutton" menu="#mm8" iconCls="icon-khgx" menuid="">8</a>
<a runat="server" href="javascript:void(0)" id="N9000" plain="false" class="easyui-menubutton" menu="#mm9" iconCls="icon-jcsz" menuid="">9</a>
<a href="javascript:void(0)" id="mb10" plain="false" class="easyui-menubutton" menu="#mm10" iconCls="icon-jcsz">10</a>
</div>

则在后台

 //遍历菜单id为mb里面的控件
foreach (Control item in mb.Controls)
{
bool con = item is HtmlAnchor; //判断是否是a标签
//如果是div span 等则 bool con = item is HtmlGenericControl; if (con)
{
HtmlAnchor link = item as HtmlAnchor;
string id = link.ID; //获取id
string menu = link.Attributes["menu"]; //获取自定义属性 因为menu不是a标签特有的属性 所以是 . 点不出来的(link.menu) 那么用Attributes 可以获取 就是key-value //你也可以这样
Control c = item as HtmlAnchor;
string temp = ((HtmlAnchor)c).Attributes["menu"];
string tempId = c.ID; }
}

C# 后台动态添加标签(span,div) 以及模板添加的更多相关文章

  1. ThinkPHP框架下,jq实现在div中添加标签并且div的大小会随之变化

    php初学者,有什么不对的还请指正. 首先是在html页面中用jq实现添加标签:divAchivePersonnal是select所在的div的外层div,divselectAchivePersonn ...

  2. Jquery 动态交换两个div位置并添加Css动画效果

    前端网页开发中我们经常会遇到需要动态置换两个DIV元素的位置,常见的思路大多是不考虑原始位置,直接采用append或者appendTo方式将两元素进行添加,该法未考虑原始位置,仅会添加为元素的最后一子 ...

  3. JS添加标签效果

    JS添加标签效果 在豆瓣网上添加自己的标签是一种常见的效果,今天也就做了一个简单的demo.由于时间的问题 我不多原理,大家可以试着操作几遍就能明白其中的原理了. JSFiddle的效果如下: 点击我 ...

  4. 【节点-添加标签】【节点-删除标签】【显示年-月-日-星期】【math算数】【正则表达式】

    1.节点-添加标签 <body><div id="div1"><p id="p1">这是一个段落.</p>< ...

  5. jquery动态为个span,input,div,等标签赋值的方法总结,js动态隐藏div

    1.jquery为span和div标签赋值. <span id="span1"></span> <div id="div1"> ...

  6. ES6面向对象 动态添加标签页

    HTML <!DOCTYPE html> <html lang="en" xmlns="http://www.w3.org/1999/xhtml&quo ...

  7. js 面向对象 动态添加标签

    有点逻辑 上代码 thml布局 点击查看代码 <!DOCTYPE html> <html lang="en"> <head> <meta ...

  8. javascript的document中的动态添加标签

    document的高级篇中提供了节点操作的函数,具体包括:获取节点,改变节点,删除节点,替换节点,创建节点,添加节点,克隆节点等函数.我们可以利用这些函数动态改变html的节点. 1.JavaScri ...

  9. EasyUI创建异步树形菜单和动态添加标签页tab

    创建异步树形菜单 创建树形菜单的ul标签 <ul class="easyui-tree" id="treeMenu"> </ul> 写j ...

随机推荐

  1. C#、Java实现按字节截取字符串包含中文汉字和英文字符数字标点符号等

    C#.Java实现按字节截取字符串,字符串中包含中文汉字和英文字符数字标点符号等. 在实际项目应用过程中,尤其是在web开发时可能遇到的比较多,就以我的(JiYF笨小孩管理系统)为例,再发布文章时候, ...

  2. How to install Wine on Ubuntu Linux 64bit

    参考地址:https://linuxconfig.org/how-to-install-wine-on-ubuntu-linux-64bit The following linux command p ...

  3. sencha touch 压缩js,css遇到的问题

    在使用工具压缩css和jss时,我遇到了以下问题 1. showBtn: { tap: function (t, value) { this.redirectTo(t.config.goto); } ...

  4. Centos 使用 docker

    公司linux服务器基本使用的Centos,以下切换为Centos进行docker的操作. 查看系统版本 [root@Sonar-104 ~]# cat /etc/redhat-release Cen ...

  5. C# 拆箱与装箱及优化

    1.概念 装箱在值类型向引用类型转换时发生,在堆中分配. 拆箱在引用类型向值类型转换时发生. 2.装箱拆箱的过程 //这行语句将整型常量1赋给object类型的变量obj:众所周知常量1是值类型,值类 ...

  6. 【BZOJ1004】[HNOI2008]Cards Burnside引理

    [BZOJ1004][HNOI2008]Cards 题意:把$n$张牌染成$a,b,c$,3种颜色.其中颜色为$a,b,c$的牌的数量分别为$sa,sb,sc$.并且给出$m$个置换,保证这$m$个置 ...

  7. Shell转义字符与变量替换

    转义字符 含义 \\ 反斜杠 \a 警报,响铃 \b 退格(删除键) \f 换页(FF),将当前位置移到下页开头 \n 换行 \r 回车 \t 水平制表符(tab键)  \v 垂直制表符 vim te ...

  8. vue之单表输入绑定

    vue的核心:声明式的指令和数据的双向绑定. 那么声明式的指令,已经给大家介绍完了.接下来我们来研究一下什么是数据的双向绑定? 另外,大家一定要知道vue的设计模式:MVVM M是Model的简写,V ...

  9. linux下pip安装pygame

    在学习python的过程中要用到pygame,在安装过程中遇到一些问题,经百度解决.因为使用的版本为python3,故以下教程针对python3版本.安装教程如下: 一.首先你要确保你已经安装了pip ...

  10. ECNU 3263 - 丽娃河的狼人传说

    一定要纪念一下第一道在比赛中自己做出来的贪心. 题目链接:http://acm.ecnu.edu.cn/problem/3263/ Time limit per test: 1.0 seconds T ...