1. 開啟新的視窗並傳送參數:
傳送參數:
Response.write("<script>window.open('*.aspx?id="+this.DropDownList1.SelectIndex+"&id1="++"')</script>")
接收參數:
string a = Request.QueryString("id");
string b = Request.QueryString("id1");
點評:次方法適合頁面配置耦合松的使用,但是如果你的頁面對布局要求比較嚴格,可能實際執行時會出現錯位,因為執行這段代碼後,會在頁面產生指令碼,這些指令碼重組瀏覽器顯示,所以導致頁面配置的編號,一個簡單的解決方案是使用RegisterClientScriptBlock方法。
2.為按鈕添加對話方塊
Button1.Attributes.Add("onclick","return confirm('確認?')");
Button.attributes.add("onclick","if(confirm('are you sure?')) {return true;}else{return false;}")
點評:如果是ASP.NET2.0還可以使用OnClientClick事件。
3.刪除表格選定記錄
int intEmpID = (int)MyDataGrid.DataKeys[e.Item.ItemIndex];
string deleteCmd = "DELETE from Employee where emp_id = " + intEmpID.ToString()
4.刪除表格記錄警告
private void DataGrid_ItemCreated(Object sender,DataGridItemEventArgs e)
{
switch(e.Item.ItemType)
{
case ListItemType.Item :
case ListItemType.AlternatingItem :
case ListItemType.EditItem:
TableCell myTableCell;
myTableCell = e.Item.Cells[14];
LinkButton myDeleteButton ;
myDeleteButton = (LinkButton)myTableCell.Controls[0];
myDeleteButton.Attributes.Add
("onclick","return confirm('您是否確定要刪除這條資訊');");
break;
default:
break;
}
}
點評:這個和上面介紹的技巧本質是一樣的
5.點擊表格行連結另一頁
private void grdCustomer_ItemDataBound
(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
//點擊表格開啟
if (e.Item.ItemType == ListItemType.Item ||
e.Item.ItemType == ListItemType.AlternatingItem)
e.Item.Attributes.Add("onclick","window.open
('Default.aspx?id=" + e.Item.Cells[0].Text + "');");
}
雙擊表格串連到另一頁,在itemDataBind事件中
if(e.Item.ItemType == ListItemType.Item ||
e.Item.ItemType == ListItemType.AlternatingItem)
{
string OrderItemID =e.item.cells[1].Text;
e.item.Attributes.Add("ondblclick", "location.href='../ShippedGrid.aspx?id=" + OrderItemID + "'");
}
雙擊表格開啟新一頁
if(e.Item.ItemType == ListItemType.Item ||
e.Item.ItemType == ListItemType.AlternatingItem)
{
string OrderItemID =e.item.cells[1].Text;
e.item.Attributes.Add("ondblclick",
"open('../ShippedGrid.aspx?id=" + OrderItemID + "')");
}
★特別注意:【?id=】 處不能為 【?id =】
6.表格超串連列傳遞參數
<asp:HyperLinkColumn Target="_blank" headertext="ID號" DataTextField="id"
NavigateUrl="aaa.aspx?id='<%# DataBinder.Eval(Container.DataItem, "資料欄位1")%>'
& name='<%# DataBinder.Eval(Container.DataItem, "資料欄位2")%>' />
7.表格點擊改變顏色
if (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem)
{
e.Item.Attributes.Add("onclick","this.style.backgroundColor='#99cc00';
this.style.color='buttontext';this.style.cursor='default';");
}
寫在DataGrid的_ItemDataBound裡
if (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem)
{
e.Item.Attributes.Add("onmouseover","this.style.backgroundColor='#99cc00';
this.style.color='buttontext';this.style.cursor='default';");
e.Item.Attributes.Add("onmouseout","this.style.backgroundColor='';this.style.color='';");
}
8.關於日期格式
日期格式設定
DataformatString="{0:yyyy-MM-dd}" ,在itembound事件中
e.items.cell["你的列"].text=DateTime.Parse(e.items.cell["你的列"].text.ToString("yyyy-MM-dd"))
9.擷取錯誤資訊併到指定頁面
不要使用Response.Redirect,而應該使用Server.Transfer
e.g
// in global.asax
protected void Application_Error(Object sender, EventArgs e) {
if (Server.GetLastError() is HttpUnhandledException)
Server.Transfer("MyErrorPage.aspx");
//其餘的非HttpUnhandledException異常交給ASP.NET自己處理就okay了
}
Redirect會導致post-back的產生從而丟失了錯誤資訊,所以頁面導嚮應該直接在伺服器端執行,這樣就可以在錯誤處理頁面得到出錯資訊並進行相應的處理
10.清空Cookie
Cookie.Expires=[DateTime];
Response.Cookies("UserName").Expires = 0
11.自訂異常處理
//自訂異常處理類
using System;
using System.Diagnostics;
namespace MyAppException
{
/**//// <summary>
/// 從系統異常類ApplicationException繼承的應用程式異常處理類。
/// 自動將異常內容記錄到Windows NT/2000的應用程式記錄檔
/// </summary>
public class AppException:System.ApplicationException
{
public AppException()
{
if (ApplicationConfiguration.EventLogEnabled)
LogEvent("出現一個未知錯誤。");
}
public AppException(string message)
{
LogEvent(message);
}
public AppException(string message,Exception innerException)
{
LogEvent(message);
if (innerException != null)
{
LogEvent(innerException.Message);
}
}