Asp.net开发常用技巧收集一

来源:互联网 发布:网络大电影 分成 开放 编辑:程序博客网 时间:2024/04/28 04:13
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会导致postback的产生从而丢失了错误信息,所以页面导向应该直接在服务器端执行,这样就可以在错误处理页面得到出错信息并进行相应的处理
  
 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);
   }
   }