B/S----Repeater控件

Repeater
Repeater是使用模板来设计界面的。它有五个模板:HeaderTemplate,FooterTemplate,ItemTemplate,AlternatingItemTemplate,SeperatorTempate

简单的数据显示思路:
1.在HTML界面中使用模板来设计展显的界面。
2.在C#界面中,查询数据,绑定显示。

步骤:
1.把Repeater拖到界面上。
做界面
2.使用DW做好界面。
3.把DW做好界面,拆开贴到Repeater不同的模板上去。
4.使用<%# Eval("列名/属性名")%>
做代码:
5.在C#代码中查询数据
6.把查询出来的数据,绑定到Repeater中显示。

用C#代码控制界面上显示:
1.在C#代码写函数。空参,返回字符串,public
2.在HTML的Repeater模板中,调用上面的方法。

一个综合练习:人员,家庭,民族,工作表。

代码:

主表”Default5.aspx“

<body>
    <form id="form1" runat="server">
    <div>

        <asp:Repeater ID="Repeater1" runat="server">
            <HeaderTemplate>
                <table width="100%" border="0" cellpadding="5" cellspacing="1" bgcolor="black">
                    <tr align="center" bgcolor="navy" style="color:white;font-weight:bold;">
                        <td width="10%">代号</td>
                        <td width="15%">姓名</td>
                        <td width="15%">性别</td>
                        <td width="15%">民族</td>
                        <td width="20%">生日</td>
                        <td width="15">操作</td>
                    </tr>
            </HeaderTemplate>
            <ItemTemplate>
                    <tr align="center" bgcolor="white" <%# showbgcolor() %>>
                        <td><%#Eval("Code") %></td>
                        <td><%# Eval("Name") %></td>
                        <td><%# Sexstring() %></td>
                        <td><%# Nationname() %></td>
                        <td><%# Birthdaystring() %></td>
                        <td>
                            <a href="Edit.aspx?id=<%# Eval("Code") %>" style="color:blue;">修改</a>
                            <a href="delete.aspx?id=<%# Eval("Code")%>" onclick="return confirm(‘确定要删除嘛?‘)" style="color:blue;">删除</a>
                        </td>
                    </tr>
            </ItemTemplate>
            <FooterTemplate>
                 </table>
            </FooterTemplate>

        </asp:Repeater>

    </div>
    </form>
</body>

主表”Default5.aspx.cs“
public partial class Default5 : System.Web.UI.Page
{
    public string Birthdaystring()
    {
        string shengri=Convert.ToDateTime(Eval("Birthday")).ToString("yyyy年MM月dd日");
        return shengri;
    }
    public string Nationname()
    {
        //先取了当前人员的民族代号
        NationData da = new NationDA().Select(Eval("Nation").ToString());
        if (da!=null)
        {
            return da.Name;
        }
        else
        {
            return "<空>";
        }

    }
    public string Sexstring()
    {
        //取人员性别数据
        bool xingbie = Convert.ToBoolean(Eval("Sex"));
        //变成字符串返回去
        bool sex = Convert.ToBoolean(Eval("Sex"));
        string pic = (sex == true) ? "boy.png" : "girl.png";
        string img = "<img src=‘image/"+pic+"‘height=‘18‘>";
        return img;
    }
    private void Fillinfo()
    {
        List<InfoData> list = new InfoDA().Select();
        Repeater1.DataSource = list;
        Repeater1.DataBind();
    }
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            Fillinfo();
        }
    }
    public string showbgcolor()
    {
        //首先找出汉族的code值
        string nationcode=Eval("Nation").ToString();
        //然后判断汉族如何,其他少数民族如何
        if (nationcode=="n001")
        {
            return "";
        }
        else
        {
            return "style=‘background-color:#ffff99;font-weight:bold;‘";
        }

    }
}

修改人员信息表”Edit.aspx.cs“

public partial class update : System.Web.UI.Page
{
    private void LoadInfo()
    {
        //把传过来的人员代号取出来
        string code = Request["id"].ToString();
        //查出当前人员的信息
        InfoData data = new InfoDA().Select(code);
        if (data!=null)
        {
            //把查出来的数据放到页面显示出来
            lblCode.Text = data.Code;
            txtName.Text = data.Name;
            rblSex.SelectedIndex = (data.Sex == true) ? 0 : 1;
            ddlNation.SelectedValue = data.Nation;
            txtBirthday.Text = data.Birthday.ToString("yyyy-MM-dd");
        }
    }
    private void FillNation()
    {
        List<NationData> list = new NationDA().Select();
        ddlNation.DataSource = list;
        ddlNation.DataTextField = "Name";
        ddlNation.DataValueField = "Code";
        ddlNation.DataBind();
    }
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            //把民族下拉列表填进数据中去
            FillNation();
            //装载当前人员的原有信息
            LoadInfo();
        }
    }
    protected void btnUpdate_Click(object sender, EventArgs e)
    {
        //取界面上的数据
        InfoData data = new InfoData();
        data.Code = lblCode.Text;
        data.Name = txtName.Text;
        data.Sex = Convert.ToBoolean(rblSex.SelectedValue);
       // data.Sex = ( rblSex.Text == "男" )? true : false;
        data.Nation = ddlNation.SelectedValue;
        data.Birthday = Convert.ToDateTime(txtBirthday.Text);
        //填到数据库中去
        new InfoDA().Update(data);
        //返回表格显示界面
        Response.Redirect("Default5.aspx");
    }
}

删除人员”delete.aspx.cs“

 protected void Page_Load(object sender, EventArgs e)
    {
        //取得要删除人员的代号
        string code = Request["id"].ToString();
        //执行删除
        FamilyDA.DeleteByInfoCode(code);
        WorkDA.DeleteByInfoCode(code);
        InfoDA.Delete(code);
        //返回列表
        Response.Redirect("Default5.aspx");
    }
}
时间: 2024-10-26 03:55:03

B/S----Repeater控件的相关文章

webform(三)Repeater控件

Repeater 控件用于显示重复的项目列表,这些项目被限制在该控件.Repeater 控件可被绑定到数据库表.XML 文件或者其他项目列表. 一.建实体类和数据访问类 建立的方法和winform一样,建立时会提示类文件应该放在App_Code文件里,是否放入,选择是,会自动创建该文件夹并将类放进去. webform没有命名空间. 实体类: public class Users { public int Ids { get; set; } public string Ucode { get; s

【2017-05-18】WebForm的Repeater控件和一些简单控件

一.Repeater控件 1. <%@ %> - 这里面写一些声明和引用的 <%  %> - 编写C#代码的 <%= %> - 往界面上输出一个变量的值 <%# Eval("属性名","可选,格式字符串")%> - 在Repeater数据展示中使用 2.Repeater控件   - 用来展示数据重复执行. <HeaderTemplate></HeaderTemplate>     先执行,执行一

Webform(Repeater控件)

一.Repeater控件 有五大模板 ItemTemplate :有多少条数据,执行多少遍        AlternatingItemTemplate : 对交替数据项进行格式设置       SeparatorTemplate : 对分隔符进行格式设置        HeaderTemplate : 对页眉进行格式设置 ,在加载开始执行一遍      FooterTemplate : 对页脚进行格式设置,在加载最后执行一遍 1.数据绑定 list<Users> li =new usersD

Repeater控件 ---表格展示数据

简介: Repeater控件是Web 服务器控件中的一个容器控件,它使您可以从页的任何可用数据中创建出自定义列表. Repeater 控件不具备内置的呈现功能,这表示用户必须通过创建模板为 Repeater 控件提供布局.当该页运行时, Repeater 控件依次通过数据源中的记录为每个记录呈现一个项. Repeater控件不具备内置的呈现功能,所以我们得用一些模板来实现他的数据呈现 下表描述了 Repeater 控件支持的模板.  模板属性                           

Repeater控件

本文转自:http://www.cnblogs.com/me115/archive/2011/04/09/2010682.html Repeater基础 在aspx文件中加入Repeater 控件,在<ItemTemplate></ItemTemplate>包含的范围里加入自己控制的代码,需要替换的变量使用<%# Eval("SellerName")%>:注意两侧的引号. .aspx: 1 <asp:Repeater ID="Sell

Repeater控件-2

本文转自:http://www.cnblogs.com/foolin/archive/2011/08/31/2161342.html 文章最后更新于2011年9月2日,增加Demo代码. 一般开发绑定数据的时候,Repeater控件是非常好用的控件,但是很多.net开发人员苦恼于无法分页,于是开发一个基于Repeater的分页控件,现在拿出来和大家一起分享分享.写得不好大家可以尽管拍砖,源码在本文后面.其实这个分页控件非常简单,分页控件只是根据记录数和当前页数等设置而输出一个分页导航条而已,并没

repeater控件实现分页

repeater控件实现排序的方法,今天我再向大家介绍repeater控件如何实现分页的效果. 分页分为真分页和假分页. 真分页:控件上一页需要显示多少数据,就从数据库取出并绑定多少数据,每次换页时都需要访问数据库. 假分页:从数据库一次性取出所有数据绑定到控件上,再将所有数据根据一页显示多少条而分页. 从以上二者的概念上我们可以看出,区别在于分页时从数据库读取信息的方式,真分页的效率无疑是最高的.假分页在首次页面加载的时候会比较慢(如果数据量较多). 二者其实各有各的优缺点,可根据需要来自行选

WebForm(四)——Repeater控件(重要、好用)

Repeater控件,可以用来一次显示一组数据项.比如,可以用它们显示一个数据表中的所有行.             Repeater控件完全由模板驱动,提供了最大的灵活性,可以任意设置它的输出格式. 一.Repeater控件显示数据 要使用Repeater控件显示数据,必须创建ItemTemplate.如下所示: 例1:使用ItemTemplate显示数据 <asp:Repeater ID="Repeater1" runat="server" DataSou

C#Repeater控件的使用

一.Repeater的用途 用来显示数据 二.Repeater的使用步骤 step1:在网页中拖入一个Repeater控件.在后台代码中,指定它的数据源,需要一个List泛型集合. public partial class query : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { Repeater1.DataSource = new FruitDA().select(); Repeate

repeater控件自定义Url分页带参数

repeater控件的效果图如下: 该页面实现的功能如下: 1.上下分页,(也可以带首页和末页,我只是禁掉了没用) 2.根据用户输入的指定分页索引进行跳转 3.根据筛选数据的参数进行URL分页的参数传递 4.数据的导出功能 前台代码: <!--表格具体内容--> <div class="table-box"> <table> <thead> <tr> <th>编号</th> <th>姓名&l