整理了一些
常用的.
NET 代码,贴出来供大家参考,并希望我们一起搜集更多的内容.
一,为 GridView 添加索引列
xml:namespace prefix = asp />
<%# Container.DataItemIndex +1 %> 二,批量删除列 模板列代码:
全选:
for (int i = 0; i < gv.Rows.Count; i++) { CheckBox chkSelect = (CheckBox)gv.Rows[i].FindControl("chkSelect"); chkSelect.Checked = true; }
反选:
for (int i = 0; i < gv.Rows.Count; i++) { CheckBox chkSelect = (CheckBox)gv.Rows[i].FindControl("chkSelect"); chkSelect.Checked = !chkSelect.Checked; }
取消选择:
for (int i = 0; i < gv.Rows.Count; i++) { CheckBox chkSelect = (CheckBox)gv.Rows[i].FindControl("chkSelect"); chkSelect.Checked = false; }
删除:
for (int i = 0; i < gv.Rows.Count; i++) {
CheckBox chkSelect = (CheckBox)gv.Rows[i].FindControl("chkSelect"); if (chkSelect.Checked) { //删除记录 } }
三,删除表格选定记录
int id = (int)MyDataGrid.DataKeys[e.Item.ItemIndex]; //在调用前必须指定 DataKeyNames 属 性为要获取
的主键. string deleteCmd = "DELETE from Employee where emp_id = " + intEmpID.ToString();
四,为按钮添加确认对话框
button.Attributes.Add("onclick","return confirm('确认?')");
五,点击表格行链接另一页
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 + "
');"); }
六,超连接列传递参数
NavigateUrl="aaa.aspx?id='
<%# DataBinder.Eval(Container.DataItem, "数据字段 1")%>' &; name=' <%# DataBinder.Eval
(Container.DataItem, "数据字段 2")%>' />
七,绑定日期格式
e.items.cell["time"].text=DateTime.Parse(e.items.cell["time"].text.ToString("yyyy-MM-dd"))
八,统一捕获异常 Global.asax 中:
protected void Application_Error(Object sender, EventArgs e) { if (Server.GetLastError() is HttpUnhandledException) Server.Transfer("MyErrorPage.aspx");
//编写添加到日志的代码 Log.add(); }
九,自定义异常处理
using System; using System.Diagnostics;
namespace MyAppException { /// /// 从系统异常类 ApplicationException 继承的应用程序异常处理类. /// 自动将异常内容记录到 Windows NT/2000 的应用程序日志 /// 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 != nul
l) { LogEvent(innerException.Message); } }
//日志记录类 using System; using System.Configuration; using System.Diagnostics; using System.IO; using System.Text; using System.Threading;
namespace MyEventLog { /// /// 事件日志记录类,提供事件日志记录支持 /// /// 定义了 4 个日志记录方法 (error, warning, info, trace) /// /// public class ApplicationLog { /// /// 将错误信息记录到 Win2000/NT 事件日志中 /// 需要记录的文本信息 /// public static void WriteError(String message) { WriteLog(TraceLevel.Error, message); }
/// /// 将警告信息记录到 Win2000/NT 事件日志中 /// 需要记录的文本信息 /// public static void WriteWarning(String message) { WriteLog(TraceLevel.Warning, message); }
/// /// 将提示信息记录到 Win2000/NT 事件日志中 /// 需要记录的文本信息 /// public static void WriteInfo(String message) { WriteLog(TraceLevel.Info, message); } /// /// 将跟踪信息记录到 Win2000/NT 事件日志中 /// 需要记录的文本信息 /// public static void WriteTrace(String message) { WriteLog(TraceLevel.Verbose, message); }
/// /// 格式化记录到事件日志的文本信息格式 /// 需要格式化的异常对象 /// 异常信息标题字符串. /// /// 格式后的异常信息字符串,包括异常内容和跟踪堆栈. /// /// public static String FormatException(Exception ex, String catchInfo) {
StringBuilder strBuilder = new StringBuilder(); if (catchInfo != String.Empty) { strBuilder.Append(catchInfo).Append("\r\n"); } strBuilder.Append(ex.Message).Append("\r\n").Append(ex.StackTrace); return strBuilder.ToString(); }
/// /// 实际事件日志写入方法 /// 要记录信息的级别(error,warning,info,trace). /// 要记录的文本. /// 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.EventLogSource Name ); //写入事件日志 eventLog.WriteEntry(messageText, LogEntryType);
} catch {} //忽略任何异常 } } //class ApplicationLog }
十,Panel 横向滚动,纵向
自动扩展
十一,DataGrid 行随鼠标变色
private void ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEvent Args e) { if (e.Item.ItemType!=ListItemType.Header) { e.Item.Attributes.Add( "onmouseout","this.style.backgroundColor=\""+e.Item.Style
["BACKGROUND-COLOR"]+"\"");
e.Item.Attributes.Add( "onmouseover","this.style.backgroundColor=\""+ "#EEE6F8"+"\""); } }
十二,读取 DataGrid 控件的 TextBox 值
foreach(DataGrid dgi in yourDataGrid.Items) {
TextBox tb = (TextBox)dgi.FindControl("yourTextBoxId"); tb.Text } .
十三,当点击编辑键时,控制文本框的大小
private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e) { for(int i=0;i 十四,弹出对话框
private static string ScriptBegin = "";
public static void ConfirmMes