2017-11-11 280 views
0

當我添加產品類別並且detailview不會自行更新時。無論如何,我可以做到這一點?Asp.net Detailview未實時更新

Product Category

detailview

這是添加類

<div class="container "style="background-color:lavender"> 
     <h2>Product Category </h2> 
<asp:DetailsView ID="DetailsViewCategory" runat="server" AutoGenerateRows="False" CellPadding="4" DataKeyNames="CategoryId" DataSourceID="SqlDataSourceCategory" DefaultMode="Insert" Height="83px" Width="360px" ForeColor="#333333" GridLines="None"> 
    <AlternatingRowStyle BackColor="White" ForeColor="#284775" /> 
    <CommandRowStyle BackColor="#E2DED6" Font-Bold="True" /> 
    <EditRowStyle BackColor="#999999" /> 
    <FieldHeaderStyle BackColor="#E9ECF1" Font-Bold="True" /> 
    <Fields> 
     <asp:BoundField DataField="CategoryId" HeaderText="CategoryId" InsertVisible="False" ReadOnly="True" SortExpression="CategoryId" /> 
     <asp:BoundField DataField="CategoryName" HeaderText="Category Name" SortExpression="CategoryName" /> 
     <asp:CommandField CancelText="" ShowInsertButton="True" /> 
    </Fields> 
    <FooterStyle BackColor="#5D7B9D" ForeColor="White" Font-Bold="True" /> 
    <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" /> 
    <PagerStyle ForeColor="White" HorizontalAlign="Center" BackColor="#284775" /> 
    <RowStyle BackColor="#F7F6F3" ForeColor="#333333" /> 
</asp:DetailsView> 
<br /> 
    </div> 

的代碼,這是我的詳細信息視圖的代碼

<asp:DetailsView ID="DetailsViewProduct" runat="server" AutoGenerateRows="False" DataKeyNames="ProductId" DataSourceID="SqlDataSourceProduct" DefaultMode="Insert" Height="16px" Width="46%" OnItemInserted="InsertProduct" HorizontalAlign="Center"> 
    <Fields> 
     <asp:TemplateField HeaderText="Picture"> 
      <EditItemTemplate> 
       <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox> 
      </EditItemTemplate> 
      <InsertItemTemplate> 
       <asp:FileUpload ID="FileUploadPicture" runat="server" Height="22px" Width="400px" CssClass="center-block" ForeColor="Black"/> 
      </InsertItemTemplate> 
      <ItemTemplate> 
       <asp:Image ID="Image1" runat="server" /> 
      </ItemTemplate> 
     </asp:TemplateField> 
     <asp:BoundField DataField="ProductId" HeaderText="ProductId" SortExpression="ProductId" InsertVisible="False" ReadOnly="True" /> 
     <asp:BoundField DataField="ProductName" HeaderText="Name" SortExpression="ProductName"/> 
     <asp:TemplateField HeaderText="Description" SortExpression="ProductDescription"> 
      <EditItemTemplate> 
       <asp:TextBox ID="TextBox2" runat="server" Text='<%# Bind("ProductDescription") %>'></asp:TextBox> 
      </EditItemTemplate> 
      <InsertItemTemplate> 
       <asp:TextBox ID="TextBox2" runat="server" Height="42px" Text='<%# Bind("ProductDescription") %>' TextMode="MultiLine" Width="400px" CssClass="center-block"></asp:TextBox> 
      </InsertItemTemplate> 
      <ItemTemplate> 
       <asp:Label ID="Label1" runat="server" Text='<%# Bind("ProductDescription") %>'></asp:Label> 
      </ItemTemplate> 
     </asp:TemplateField> 
     <asp:TemplateField HeaderText="Category" SortExpression="ProductCategory"> 
      <EditItemTemplate> 
       <asp:TextBox ID="TextBox3" runat="server" Text='<%# Bind("ProductCategory") %>'></asp:TextBox> 
      </EditItemTemplate> 
      <InsertItemTemplate> 
       <asp:SqlDataSource ID="SqlDataSourcePC" runat="server" ConnectionString="<%$ ConnectionStrings:DefaultConnection %>" SelectCommand="SELECT * FROM [ProductCategory]"></asp:SqlDataSource> 
       <asp:DropDownList ID="DropDownList3" runat="server" DataSourceID="SqlDataSourcePC" DataTextField="CategoryName" DataValueField="CategoryId" Height="18px" SelectedValue='<%# Bind("ProductCategory") %>' Width="400px" CssClass="center-block"> 
       </asp:DropDownList> 
      </InsertItemTemplate> 
      <ItemTemplate> 
       <asp:Label ID="Label2" runat="server" Text='<%# Bind("ProductCategory") %>'></asp:Label> 
      </ItemTemplate> 
     </asp:TemplateField> 
     <asp:TemplateField HeaderText="Brand" SortExpression="ProductBrand"> 
      <EditItemTemplate> 
       <asp:TextBox ID="TextBox4" runat="server" Text='<%# Bind("ProductBrand") %>'></asp:TextBox> 
      </EditItemTemplate> 
      <InsertItemTemplate> 
       <asp:SqlDataSource ID="SqlDataSourceBrand1" runat="server" ConnectionString="<%$ ConnectionStrings:DefaultConnection %>" SelectCommand="SELECT * FROM [ProductBrand]"></asp:SqlDataSource> 
       <asp:DropDownList ID="DropDownList6" runat="server" DataSourceID="SqlDataSourceBrand1" DataTextField="ProductBrand" DataValueField="BrandId" SelectedValue='<%# Bind("ProductBrand") %>' Width="400px" CssClass="center-block"> 
       </asp:DropDownList> 
      </InsertItemTemplate> 
      <ItemTemplate> 
       <asp:Label ID="Label3" runat="server" Text='<%# Bind("ProductBrand") %>'></asp:Label> 
      </ItemTemplate> 
     </asp:TemplateField> 
     <asp:BoundField DataField="ProductPrice" HeaderText="Price (RM)" SortExpression="ProductPrice" /> 
     <asp:BoundField DataField="ProductQty" HeaderText="Stock Quantity" SortExpression="ProductQty" /> 
     <asp:CommandField CancelText="" ShowInsertButton="True" /> 
    </Fields> 
</asp:DetailsView> 
+0

向我們展示一些代碼以及迄今爲止嘗試的內容。 – Pyves

+0

請閱讀[在什麼情況下,我可以添加「緊急」或其他類似的短語到我的問題,以獲得更快的答案?](/ meta.stackoverflow.com/q/326569) - 總結是,這不是這是解決志願者問題的理想方式,可能會對獲得答案產生反作用。請不要將這添加到您的問題。 – halfer

+0

值得注意的是,故意通過添加廢話故意規避郵編長度的編輯限制可能會吸引downvotes,這並非完全不當。如果你得到這個警告,考慮你可能增加的其他細節,而不是讓志願者編輯更多的工作來做':-)'。 – halfer

回答

1

是數據控件不更新自動爲他們需要頁面重新加載d數據綁定。在頁面加載事件中調用您的控件的DataBind()方法

DetailsViewCategory.DataBind();