在GridView ASP.NET中设置用户控件对象属性

时间:2015-07-30 18:26:41

标签: c# asp.net gridview user-controls

我在gridview中插入了三个模板列。在每列中我插入一个用户控件。例如,在第一列中,有一个用户控件包含一个图像和三个标签。

在我的页面加载中,我需要获取文件夹中的图像列表并为每个图像创建一行。然后我需要在gridview列中更新这些用户控件的图像。

以下是获取图像列表的示例代码,它将成为GridView的数据源:

        string[] filePaths = Directory.GetFiles(Server.MapPath("~/Resources/Pictures"));
        GridView1.DataSource = filePaths;
        GridView1.DataBind();

在这一步中,我可以看到4行已经填充了RAW用户控件(图像控件中的空图像,标签的默认文本等)。现在我需要用自己的属性更新每一行。

这是我输出的图片:

enter image description here

正如您在第一列中看到的,有一些用于用户控件的控件(图像和标签),我在gridview的列模板中使用它们。但它们是RAW,我需要更新它们。例如,我需要使用您在第三列中看到的链接更新图像。

以下是我的GridView代码的一部分:

<asp:GridView ID="GridView1" runat="server" BackColor="LightGoldenrodYellow" BorderColor="Tan" BorderWidth="1px" Caption="Image List" CellPadding="2" ForeColor="Black" GridLines="None" Height="222px" Width="409px">
    <AlternatingRowStyle BackColor="PaleGoldenrod" />
    <Columns>
        <asp:TemplateField HeaderText="Old Picture">
            <ItemTemplate>
                <uc1:ImageColumn ID="ImageColumn1" runat="server" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="New Picture">
            <ItemTemplate>
                <uc2:ReplaceColumn ID="ReplaceColumn1" runat="server" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="Allow Access">
            <ItemTemplate>
                <asp:Image ID="Image1" runat="server" />
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>

希望它足够清楚。请帮忙吗?

1 个答案:

答案 0 :(得分:1)

您必须向用户控件添加公共属性,然后使用“普通”数据绑定表达式进行设置。 E.g:

用户控制:

public class MyUserControl : UserControl
{
    public string ImageName {get; set;}
}

grid的模板列:

<asp:TemplateField ...>
    <ItemTemplate>
        <uc1:MyUserControl runat="server" ImageName='<%# Eval("ImageUrl")%>' ... />

代码隐藏:

public class ImageVM { // view-model for data-binding
    public string ImageUrl { get; set; }
}

...

var images = LoadImages(); // returns a list of ImageVM instances
grid.DataSource = images;
grid.DataBind();