asp.net开发常用技巧收集(2)
点击次数:16 次 发布日期:2008-11-26 14:18:13 作者:源代码网
|
源代码网推荐 源代码网推荐 <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); 源代码网推荐 } 源代码网推荐 } 源代码网推荐 源代码网推荐 //日志记录类 源代码网推荐 using System; 源代码网推荐 using System.Configuration; 源代码网推荐 using System.Diagnostics; 源代码网推荐 using System.IO; 源代码网推荐 using System.Text; 源代码网推荐 using System.Threading; 源代码网推荐 源代码网推荐 namespace MyEventLog 源代码网推荐 { 源代码网推荐 /**//// <summary> 源代码网推荐 /// 事件日志记录类,提供事件日志记录支持 源代码网推荐 /// <remarks> 源代码网推荐 /// 定义了4个日志记录方法 (error, warning, info, trace) 源代码网推荐 /// </remarks> 源代码网推荐 /// </summary> 源代码网推荐 public class ApplicationLog 源代码网推荐 { 源代码网推荐 /**//// <summary> 源代码网推荐 /// 将错误信息记录到Win2000/NT事件日志中 源代码网推荐 /// <param name="message">需要记录的文本信息</param> 源代码网推荐 /// </summary> 源代码网推荐 public static void WriteError(String message) 源代码网推荐 { 源代码网推荐 源代码网推荐 WriteLog(TraceLevel.Error, message); 源代码网推荐 } 源代码网推荐 源代码网推荐 /**//// <summary> 源代码网推荐 /// 将警告信息记录到Win2000/NT事件日志中 源代码网推荐 /// <param name="message">需要记录的文本信息</param> 源代码网推荐 /// </summary> 源代码网推荐 public static void WriteWarning(String message) 源代码网推荐 { 源代码网推荐 源代码网推荐 WriteLog(TraceLevel.Warning, message); 源代码网推荐 } 源代码网推荐 源代码网推荐 /**//// <summary> 源代码网推荐 /// 将提示信息记录到Win2000/NT事件日志中 源代码网推荐 /// <param name="message">需要记录的文本信息</param> 源代码网推荐 /// </summary> 源代码网推荐 public static void WriteInfo(String message) 源代码网推荐 { 源代码网推荐 WriteLog(TraceLevel.Info, message); 源代码网推荐 } 源代码网推荐 /**//// <summary> 源代码网推荐 /// 将跟踪信息记录到Win2000/NT事件日志中 源代码网推荐 /// <param name="message">需要记录的文本信息</param> 源代码网推荐 /// </summary> 源代码网推荐 public static void WriteTrace(String message) 源代码网推荐 { 源代码网推荐 源代码网推荐 WriteLog(TraceLevel.Verbose, message); 源代码网推荐 } 源代码网推荐 /**//// <summary> 源代码网推荐 /// 格式化记录到事件日志的文本信息格式 源代码网推荐 /// <param name="ex">需要格式化的异常对象</param> 源代码网推荐 /// <param name="catchInfo">异常信息标题字符串.</param> 源代码网推荐 /// <retvalue> 源代码网推荐 /// <para>格式后的异常信息字符串,包括异常内容和跟踪堆栈.</para> 源代码网推荐 /// </retvalue> 源代码网推荐 /// </summary> 源代码网推荐 public static String formatException(Exception ex, String catchInfo) 源代码网推荐 { 源代码网推荐 StringBuilder strBuilder = new StringBuilder(); 源代码网推荐 if (catchInfo != String.Empty) 源代码网推荐 { 源代码网推荐 strBuilder.Append(catchInfo).Append(" "); 源代码网推荐 } 源代码网推荐 strBuilder.Append(ex.Message).Append(" ").Append(ex.StackTrace); 源代码网推荐 return strBuilder.ToString(); 源代码网推荐 } 源代码网推荐 源代码网推荐 /**//// <summary> 源代码网推荐 /// 实际事件日志写入方法 源代码网推荐 /// <param name="level">要记录信息的级别(error,warning,info,trace).</param> 源代码网推荐 /// <param name="messageText">要记录的文本.</param> 源代码网推荐 /// </summary> 源代码网推荐 private static void WriteLog(TraceLevel level, String messageText) 源代码网推荐 { 源代码网推荐 源代码网推荐 try 源代码网推荐 { 源代码网推荐 EventLogEntryType LogEntryType; 源代码网推荐 switch (level) 源代码网推荐 { 源代码网推荐 case TraceLevel.Error: 源代码网推荐 LogEntryType = EventLogEntryType.Error; 源代码网推荐 break; 源代码网推荐 case TraceLevel.Warning: 源代码网推荐 LogEntryType = EventLogEntryType.Warning; 源代码网推荐 break; 源代码网推荐 case TraceLevel.Info: 源代码网推荐 LogEntryType = EventLogEntryType.Information; 源代码网推荐 break; 源代码网推荐 case TraceLevel.Verbose: 源代码网推荐 LogEntryType = EventLogEntryType.SuccessAudit; 源代码网推荐 break; 源代码网推荐 default: 源代码网推荐 LogEntryType = EventLogEntryType.SuccessAudit; 源代码网推荐 break; 源代码网推荐 } 源代码网推荐 源代码网推荐 EventLog eventLog = new EventLog("Application", ApplicationConfiguration.EventLogMachineName, ApplicationConfiguration.EventLogSourceName ); 源代码网推荐 //写入事件日志 源代码网推荐 eventLog.WriteEntry(messageText, LogEntryType); 源代码网推荐 源代码网推荐 } 源代码网推荐 catch {} //忽略任何异常 源代码网推荐 } 源代码网推荐 } //class ApplicationLog 源代码网推荐 } 源代码网推荐 做人要厚道,请注明转自酷网动力(www.ASPCOOL.COM)。 源代码网推荐 源代码网供稿. |
