我们可以添加多种单元格类型到 C1GridView。链接中的文档详细的阐述了C1GridView内置的单元格类型。在这些单元格类型中,C1TemplateField 可以通过定制来满足不同的用户需求。我们可以通过 C1TemplateField 下ItemTemplate 属性,在 Grid 加载时绑定数据源到 C1TemplateField。同时,我们可以通过 EditItemTemplate 属性作为 C1TemplateField 的编辑器。可以参考 “<wijmo:C1GridView ID="C1GridView1" runat="server" AutogenerateColumns="False" DataKeyNames="CustomerID"
DataSourceID="AccessDataSource1" OnRowUpdating="C1GridView1_RowUpdating">
<Columns>
<wijmo:C1BoundField DataField="CustomerID" HeaderText="CustomerID" ReadOnly="True"
SortExpression="CustomerID">
</wijmo:C1BoundField>
<wijmo:C1BoundField DataField="CustomerName" HeaderText="CustomerName" SortExpression="CustomerName">
</wijmo:C1BoundField>
<wijmo:C1TemplateField HeaderText="Country">
<ItemTemplate>
<span>
<%# Eval("Country") %></span>
</ItemTemplate>
<EditItemTemplate>
<asp:DropDownList ID="dlCountry" runat="server" DataSourceID="AccessDataSource2"
DataTextField="Country" DataValueField="Country" SelectedValue='<%# Bind("Country") %>'>
</asp:DropDownList>
<asp:AccessDataSource ID="AccessDataSource2" runat="server" DataFile="~/App_Data/C1NWind1.mdb"
SelectCommand="SELECT * FROM [Countries]"></asp:AccessDataSource>
</EditItemTemplate>
</wijmo:C1TemplateField>
<wijmo:C1CommandField ShowEditButton="True">
</wijmo:C1CommandField>
</Columns>
</wijmo:C1GridView>
<asp:AccessDataSource ID="AccessDataSource1" runat="server" DataFile="~/App_Data/C1NWind1.mdb"
SelectCommand="SELECT * FROM [Customers]" >
</asp:AccessDataSource>
下列图片展示了允许程序的初始界面: 下面,我们可以点击 Edit 按钮使 C1GridView 更新到编辑状态。我们可以看到 DropDownList 弹出,通过 DropDownList 我们可以选择目标项。截图: 在选择目标选项后,点击 Update 按钮完成更新,此时,我们需要通过 UpdateCommand 事件来更新数据源,实现代码如下: 更详细信息请参考 Demo:protected void C1GridView1_RowUpdating(object sender, C1.Web.Wijmo.Controls.C1GridView.C1GridViewUpdateEventArgs e)
{
AccessDataSource1.UpdateCommand = "Update Customers Set CustomerName=@CustomerName, Country=@Country where CustomerID=@CustomerID";
AccessDataSource1.UpdateParameters.Add("CustomerID",e.Keys["CustomerID"].ToString());
AccessDataSource1.UpdateParameters.Add("CustomerName", e.NewValues["CustomerName"].ToString());
AccessDataSource1.UpdateParameters.Add("Country", e.NewValues["Country"].ToString());
AccessDataSource1.Update();
}
关于葡萄城
葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。
葡萄城热门产品
活字格
打通现有软件,快速定制面向未来的个性化应用

SpreadJS
可嵌入您系统的在线Excel的纯前端表格控件

Wyn商业智能
可与企业自有系统深度集成,增强数据分析的 BI 工具
