ASP.NET自定义Web服务器控件-Div控件

40 篇文章 0 订阅
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
//自定义web服务器div控件
namespace MyControls
{
    [DefaultProperty("Text")]
    [ToolboxData("<{0}:MyDiv runat=server></{0}:MyDiv>")]
    [ParseChildren(true,"Students")]
    public class MyDiv : WebControl
    {
        //第一种方式
        //private List<Student> _student;
        //[PersistenceMode(PersistenceMode.InnerDefaultProperty)] //默认集合
        //public List<Student> Students {
        //    get {
        //        if (_student == null) {
        //            _student = new List<Student>();
        //        }
        //        return _student;
        //    }
        //    set {
        //        _student = value;
        //    }
        //}
        //第二种方式
        [PersistenceMode(PersistenceMode.InnerDefaultProperty)] //默认集合
        public List<Student> Students
        {
            get
            {
                if (ViewState["Students"] == null)
                {
                    ViewState["Students"] = new Size();
                }
                return (List<Student>)ViewState["Students"];
            }
            set
            {
                ViewState["Students"] = value;
            }
        }


       [DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]//以内容的形式打印
        public Size Size {
            get {
                if (ViewState["Size"] == null) { 
                    ViewState["Size"]=  new Size();
                }
                return (Size)ViewState["Size"];
            }
            set {
                ViewState["Size"] = value;
            }
        }
        protected override HtmlTextWriterTag TagKey
        {
            get
            {
                return HtmlTextWriterTag.Div;//层标签
            }
        }
        protected override void OnInit(EventArgs e)
        {
            base.OnInit(e);
        }
        public override void RenderBeginTag(HtmlTextWriter writer)
        {
            this.Style.Add("Width", Size.Width + "px");//增加样式
            this.Style.Add("Height", Size.Height + "px");
            this.Style.Add("border","1px solid red");
            base.RenderBeginTag(writer);
        }
        protected override void RenderContents(HtmlTextWriter writer)
        {
            //打印层内容
            foreach (Student stu in Students) {
                writer.Write("<p>姓名:"+stu.Name+"年龄:"+stu.Age+"性别:"+stu.Sex+"</p>");
            }            
            base.RenderContents(writer);
        }
    }
}

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

//子标签-自定义服务器Div控件的子标签
namespace MyControls
{
   public class Student
    {
       public string Name { set; get; }
       public string Sex { set; get; }
       public int Age { set; get; }
       public Student() { }
       public Student(string name, string sex, int age) {
           this.Age = age;
           this.Name = name;
           this.Sex = sex;
       }
    }
}

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

 //<cc1:MyButton ID="MyButton1" Size-Height="30" Size-Width="290" OnClick="btnSubmit" Text="我是一个单独的提交按钮(自定义服务器)" runat="server" />用于这种内部属性
//定义一个大小的类,里面包含了宽高
namespace MyControls
{
   public class Size
    {
       public int Width { set; get; }
       public int Height { set; get; }
       public Size(int width,int height) {
           this.Width = width;
           this.Height = height;
       }
       public Size() : this(100,100) { }
    }
}

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

<%@ Register assembly="MyControls" namespace="MyControls" tagprefix="cc1" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    <!--自定义服务器Div控件-->
        <cc1:MyDiv ID="MyDiv2"  Size-Height="200" Size-Width="400" runat="server">
             <cc1:Student Age="12" Sex="男" Name="某某某1" />
             <cc1:Student Age="13" Sex="女" Name="某某某2" />
             <cc1:Student Age="14" Sex="男" Name="某某某3" />
             <cc1:Student Age="15" Sex="女" Name="某某某4" />
        </cc1:MyDiv>
    </div>
 
    
    </form>

</body>
</html>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值