2014-01-17 78 views
1

我试图建立一个gridview和细节来管理用户笔记。textarea里面detailsview asp.net

一切工作正常,但我需要与多添加详细信息视图中的文本框:

<asp:DetailsView ID="DetailsView1" ClientIDMode="Static" runat="server" SkinID="detailview" AllowPaging="True" Width="700px" AutoGenerateRows="False" DataKeyNames="id,Expr1" DataSourceID="SqlDataSource2" HeaderText="الملاحظات" oniteminserted="updategridview" onitemupdated="updategridview"> 
      <Fields> 
       <asp:BoundField DataField="id" HeaderText="id" InsertVisible="False" ReadOnly="True" SortExpression="id" /> 
       <asp:BoundField DataField="user_id" HeaderText="user_id" SortExpression="user_id" /> 
       <asp:BoundField DataField="xdate" HeaderText="xdate" SortExpression="xdate" /> 
       <asp:TemplateField HeaderText="xcontent"> 
        <ItemTemplate> 
         <asp:Label ID="Label1" runat="server" Text='<%# Eval("xcontent") %>'></asp:Label> 
        </ItemTemplate> 
        <EditItemTemplate> 
         <asp:TextBox ID="update" ClientIDMode="Static" TextMode="MultiLine" Text='<%# Eval("xcontent") %>' Height="100px" runat="server"></asp:TextBox> 
        </EditItemTemplate> 
        <InsertItemTemplate> 
         <asp:TextBox ID="insert" ClientIDMode="Static" TextMode="MultiLine" Text="" Height="100px" runat="server"></asp:TextBox> 
        </InsertItemTemplate> 
       </asp:TemplateField> 
       <asp:BoundField DataField="name" HeaderText="name" SortExpression="name" /> 
       <asp:CommandField ShowInsertButton="True" /> 
       <asp:CommandField ShowEditButton="True"/> 
      </Fields> 
     </asp:DetailsView> 


    <asp:SqlDataSource ID="SqlDataSource2" runat="server" ConnectionString="<%$ ConnectionStrings:samy_sarc %>" InsertCommand="INSERT INTO sarcusernote(user_id, xdate, xcontent) VALUES (@user_id, @xdate, @xcontent)" SelectCommand="SELECT sarcusernote.*,(select firstname from sarcuser where id=2) as name, id AS Expr1 FROM sarcusernote WHERE (id = @id)" UpdateCommand="UPDATE sarcusernote SET user_id = @user_id, xdate = @xdate, xcontent = @xcontent WHERE (id = @id)"> 
     <InsertParameters> 
      <asp:Parameter Name="user_id" /> 
      <asp:Parameter Name="xdate" /> 
      <asp:ControlParameter ControlID="insert" DefaultValue="%" Name="xcontent" PropertyName="Text" /> 
     </InsertParameters> 
     <SelectParameters> 
      <asp:ControlParameter ControlID="GridView1" DefaultValue="0" Name="id" PropertyName="SelectedValue" /> 
     </SelectParameters> 
     <UpdateParameters> 

      <asp:Parameter Name="user_id" /> 
      <asp:Parameter Name="xdate" /> 
      <asp:ControlParameter ControlID="update" Name="xcontent" PropertyName="Text" Type="String" DefaultValue="%" /> 
      <asp:Parameter Name="id" /> 
     </UpdateParameters> 
    </asp:SqlDataSource> 

有查询中没有任何错误......因为它的做工精细。 问题是当我更新或插入一些值时有这些错误:

异常详细信息:System.InvalidOperationException:在ControlParameter'xcontent'中找不到控件'update'。

plz帮助

回答

2

的问题是,你的ControlParameter找不到嵌套一个DetailsView INSIDE公司的控制(因为它是在一个不同的ContentTemplate)。通常有两种方法可以解决这个问题。

方法1:使用“$”符号访问嵌套控件。

您可以更新您的标记是这样的:

<asp:ControlParameter ControlID="DetailsView1$update" Name="xcontent" 
    PropertyName="Text" Type="String" DefaultValue="%" /> 

使用{outerControlID}${innerControlID}可以让你的ControlParameter找到嵌套的控制。

方法2:在代码隐藏中添加参数。

您可以通过编程将控件添加到代码隐藏中的UpdateParameters集合中。这更多的是黑客攻击,但如果你需要的话,我可以举个例子。

+1

感谢您的详细信息和解决方案 第一种方法适用于我。 –

+0

非常欢迎您,@SamySammour。我很高兴我能帮忙=) – jadarnel27