這兩天一直在考慮如何設定新聞釋出系統的文章稽核模式。初步思路是通過一個"Button"來控制稽核狀态,在綁定GridView的時候通過表中的字段isshow來設定"Button"的屬性。如果isshow=1, 則 btn.Text = "已稽核"; btn.Enabled = false;如果isshow=0,則 btn.Text = "稽核";btn.Enabled = true; isshow=0是指文章剛被編輯好,管理者還未稽核這篇文章是否正确,當管理者認為無誤以後,點選“稽核”按鈕,将isshow設定為1,這樣前台就能看到被稽核過的文章。
下面列出前台aspx中的關于GridView的代碼:
<asp:GridView ID="pageGridView" runat="server" AutoGenerateColumns="False" DataKeyNames="info_id"
OnRowCommand="pageGridView_RowCommand">
<Columns>
<asp:BoundField DataField="info_id" HeaderText="序号" SortExpression="info_id" HtmlEncode="False">
<HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />
<ItemStyle Font-Size="Small" />
</asp:BoundField>
<asp:TemplateField HeaderText="标題">
<ItemTemplate>
<asp:HyperLink ID="HyperLink1" CssClass="biao_t" runat="server" Font-Size="Small"
Target="_blank" Text='<%#DataBinder.Eval(Container.DataItem,"INFO_TITLE")%>'
NavigateUrl='<%#"../eNews/showNews.aspx?info_id="+HttpUtility.UrlEncode(DataBinder.Eval(Container.DataItem,"INFO_ID").ToString())%>'>HyperLink</asp:HyperLink>
</ItemTemplate>
<ItemStyle HorizontalAlign="Left" />
</asp:TemplateField>
<asp:BoundField DataField="info_addtime" HeaderText="時間" SortExpression="info_addtime"
DataFormatString="[{0:yyyy-MM-dd}]" HtmlEncode="False">
<asp:TemplateField HeaderText="删除">
<asp:CheckBox ID="CheckBox1" runat="server" />
<HeaderTemplate>
<input id="chkSelectAll" onclick="ChooseAll()" type="checkbox" name="chkSelectAll"><font
size="2">全選</font>
</HeaderTemplate>
<asp:TemplateField HeaderText="編輯">
<asp:HyperLink ID="HyperLink2" runat="server" CssClass="sh_hr" NavigateUrl='<%#"editNews.aspx?info_id="+HttpUtility.UrlEncode(DataBinder.Eval(Container.DataItem,"INFO_ID").ToString())%>'
Text="編輯">
</asp:HyperLink>
<asp:TemplateField HeaderText="稽核狀态">
<asp:Button ID="Button1" runat="server" Text="Button" CommandArgument='<%#Eval("info_id") %>'
CommandName="approval" />
</Columns>
</asp:GridView>
從中我們看出我們綁定了“序号”“标題”“時間”“全選”“編輯”“稽核”這一些字段。有些直接就是資料庫中的字段,比如“序号”和“時間”。而有些則不是,可能是超連結,也可能是按鈕等等。
下面我們看pageGridView_RowCommand()中的定義:
protected void pageGridView_RowCommand(object sender, GridViewCommandEventArgs e)
{
if(e.CommandName=="approval")
{
//取ID的值方法一 success
GridViewRow drv = ((GridViewRow)(((Button)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被選中的索引值
int id = Convert.ToInt32(pageGridView.DataKeys[drv.RowIndex].Value); //此擷取的值為GridView中綁定資料庫中的主鍵值
//取ID的值方法二 隻有當GridView中有info_id字段是才成功
//此擷取的值為GridView中綁定資料庫中的主鍵值,取值方法是選中的行中的第一列的值,drv.RowIndex取得是選中行的索引
int id = Convert.ToInt32(pageGridView.Rows[drv.RowIndex].Cells[0].Text);
//取ID的值方法三 success
//因為在用戶端中就已經将LinkButton的CommandArgument與主鍵Id給綁定了是以在此可以直接用e.CommandArgument得出主鍵ID的值
int id = Convert.ToInt32(e.CommandArgument.ToString());
if (NewsBus.setIsShow(id))
{
this.Label1.Text = "成功!";
this.GridViewBind();
}
else
this.Label1.Text = "失敗!";
}
}
其中方法一和方法三如注釋中顯示的,都通過了驗證,隻有方法二情況比較特殊,pageGridView.Rows[drv.RowIndex].Cells[0].Text獲得的隻是GridView表格中的第“索引”行的第一列,如果我們沒有在GridView中添加
<asp:BoundField DataField="info_id" HeaderText="序号" SortExpression="info_id" HtmlEncode="False">
<HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />
<ItemStyle Font-Size="Small" />
</asp:BoundField>
那麼就擷取不到目前行的主鍵,是以方法二的應用是有前提的。我們這裡就沒有添加“序号”列,是以使用了方法三。
本文轉自xwdreamer部落格園部落格,原文連結:http://www.cnblogs.com/xwdreamer/archive/2010/03/28/2297144.html,如需轉載請自行聯系原作者