ASPNET程序中常用的三十三种代码.docx
《ASPNET程序中常用的三十三种代码.docx》由会员分享,可在线阅读,更多相关《ASPNET程序中常用的三十三种代码.docx(25页珍藏版)》请在冰点文库上搜索。
ASPNET程序中常用的三十三种代码
1.打开新的窗口并传送参数:
传送参数:
response.write("<script>window.open(’*.aspx?
id="+this.DropDownList1.SelectIndex+"&id1="+...+"’)</script>")
接收参数:
stringa=Request.QueryString("id");
stringb=Request.QueryString("id1");
2.为按钮添加对话框
Button1.Attributes.Add("onclick","returnconfirm(’确认?
’)");
button.attributes.add("onclick","if(confirm(’areyousure...?
’)){returntrue;}else{returnfalse;}")
3.删除表格选定记录
intintEmpID=(int)MyDataGrid.DataKeys[e.Item.ItemIndex];
stringdeleteCmd="DeletefromEmployeewhereemp_id="+intEmpID.ToString()
4.删除表格记录警告
privatevoidDataGrid_ItemCreated(Objectsender,DataGridItemEventArgse)
{
switch(e.Item.ItemType)
{
caseListItemType.Item:
caseListItemType.AlternatingItem:
caseListItemType.EditItem:
TableCellmyTableCell;
myTableCell=e.Item.Cells[14];
LinkButtonmyDeleteButton;
myDeleteButton=(LinkButton)myTableCell.Controls[0];
myDeleteButton.Attributes.Add("onclick","returnconfirm(’您是否确定要删除这条信息’);");
break;
default:
break;
}
}
5.点击表格行链接另一页
privatevoidgrdCustomer_ItemDataBound(objectsender,System.Web.UI.WebControls.DataGridItemEventArgse)
{
//点击表格打开
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)
{
stringorderItemID=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)
{
stringorderItemID=e.item.cells[1].Text;
...
e.item.Attributes.Add("ondblclick","open(’../ShippedGrid.aspx?
id="+orderItemID+"’)");
}
6.表格超连接列传递参数
<asp:
HyperLinkColumnTarget="_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
//inglobal.asax
protectedvoidApplication_Error(Objectsender,EventArgse){
if(Server.GetLastError()isHttpUnhandledException)
Server.Transfer("MyErrorPage.aspx");
//其余的非HttpUnhandledException异常交给ASP.NET自己处理就okay了:
)
}
Redirect会导致post-back的产生从而丢失了错误信息,所以页面导向应该直接在服务器端执行,这样就可以在错误处理页面得到出错信息并进行相应的处理
10.清空Cookie
Cookie.Expires=[DateTime];
Response.Cookies("UserName").Expires=0
11.自定义异常处理
//自定义异常处理类
usingSystem;
usingSystem.Diagnostics;
namespaceMyAppException
{
///<summary>
///从系统异常类ApplicationException继承的应用程序异常处理类。
///自动将异常内容记录到WindowsNT/2000的应用程序日志
///</summary>
publicclassAppException:
System.ApplicationException
{
publicAppException()
{
if(ApplicationConfiguration.EventLogEnabled)LogEvent("出现一个未知错误。
");
}
publicAppException(stringmessage)
{
LogEvent(message);
}
publicAppException(stringmessage,ExceptioninnerException)
{
LogEvent(message);
if(innerException!
=null)
{
LogEvent(innerException.Message);
}
}
//日志记录类
usingSystem;
usingSystem.Configuration;
usingSystem.Diagnostics;
usingSystem.IO;
usingSystem.Text;
usingSystem.Threading;
namespaceMyEventLog
{
///<summary>
///事件日志记录类,提供事件日志记录支持
///<remarks>
///定义了4个日志记录方法(error,warning,info,trace)
///</remarks>
///</summary>
publicclassApplicationLog
{
///<summary>
///将错误信息记录到Win2000/NT事件日志中
///<paramname="message">需要记录的文本信息</param>
///</summary>
publicstaticvoidWriteError(Stringmessage)
{
WriteLog(TraceLevel.Error,message);
}
///<summary>
///将警告信息记录到Win2000/NT事件日志中
///<paramname="message">需要记录的文本信息</param>
///</summary>
publicstaticvoidWriteWarning(Stringmessage)
{
WriteLog(TraceLevel.Warning,message);
}
///<summary>
///将提示信息记录到Win2000/NT事件日志中
///<paramname="message">需要记录的文本信息</param>
///</summary>
publicstaticvoidWriteInfo(Stringmessage)
{
WriteLog(TraceLevel.Info,message);
}
///<summary>
///将跟踪信息记录到Win2000/NT事件日志中
///<paramname="message">需要记录的文本信息</param>
///</summary>
publicstaticvoidWriteTrace(Stringmessage)
{
WriteLog(TraceLevel.Verbose,message);
}
///<summary>
///格式化记录到事件日志的文本信息格式
///<paramname="ex">需要格式化的异常对象</param>
///<paramname="catchInfo">异常信息标题字符串.</param>
///<retvalue>
///<para>格式后的异常信息字符串,包括异常内容和跟踪堆栈.</para>
///</retvalue>
///</summary>
publicstaticStringFormatException(Exceptionex,StringcatchInfo)
{
StringBuilderstrBuilder=newStringBuilder();
if(catchInfo!
=String.Empty)
{
strBuilder.Append(catchInfo).Append("\r\n");
}
strBuilder.Append(ex.Message).Append("\r\n").Append(ex.StackTrace);
returnstrBuilder.ToString();
}
///<summary>
///实际事件日志写入方法
///<paramname="level">要记录信息的级别(error,warning,info,trace).</param>
///<paramname="messageText">要记录的文本.</param>
///</summary>
privatestaticvoidWriteLog(TraceLevellevel,StringmessageText)
{
try
{
EventLogEntryTypeLogEntryType;
switch(level)
{
caseTraceLevel.Error:
LogEntryType=EventLogEntryType.Error;
break;
caseTraceLevel.Warning:
LogEntryType=EventLogEntryType.Warning;
break;
caseTraceLevel.Info:
LogEntryType=EventLogEntryType.Information;
break;
caseTraceLevel.Verbose:
LogEntryType=EventLogEntryType.SuccessAudit;
break;
default:
LogEntryType=EventLogEntryType.SuccessAudit;
break;
}
EventLogeventLog=newEventLog("Application",ApplicationConfiguration.EventLogMachineName,ApplicationConfiguration.EventLogSourceName);
//写入事件日志
eventLog.WriteEntry(messageText,LogEntryType);
}
catch{}//忽略任何异常
}
}//classApplicationLog
}
12.Panel横向滚动,纵向自动扩展
<asp:
panelstyle="overflow-x:
scroll;overflow-y:
auto;"></asp:
panel>
13.回车转换成Tab
<scriptlanguage="javascript"for="document"event="onkeydown">
if(event.keyCode==13&&event.srcElement.type!
=’button’&&event.srcElement.type!
=’submit’&& event.srcElement.type!
=’reset’&&event.srcElement.type!
=’’&&event.srcElement.type!
=’textarea’);
event.keyCode=9;
</script>
onkeydown="if(event.keyCode==13)event.keyCode=9"
14.DataGrid超级连接列
DataNavigateUrlField="字段名"DataNavigateUrlFormatString="http:
//xx/inc/delete.aspx?
ID={0}"
15.DataGrid行随鼠标变色
privatevoidDGzf_ItemDataBound(objectsender,System.Web.UI.WebControls.DataGridItemEventArgse)
{
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=\""+"#EFF3F7"+"\"");
}
}
16.模板列
<ASP:
TEMPLATECOLUMNvisible="False"sortexpression="demo"headertext="ID">
<ITEMTEMPLATE>
<ASP:
LABELtext=’<%#DataBinder.Eval(Container.DataItem,"ArticleID")%>’runat="server"width="80%"id="lblColumn"/>
</ITEMTEMPLATE>
</ASP:
TEMPLATECOLUMN>
<ASP:
TEMPLATECOLUMNheadertext="选中">
<HEADERSTYLEwrap="False"horizontalalign="Center"></HEADERSTYLE>
<ITEMTEMPLATE>
<ASP:
CHECKBOXid="chkExport"runat="server"/>
</ITEMTEMPLATE>
<EDITITEMTEMPLATE>
<ASP:
CHECKBOXid="chkExportON"runat="server"enabled="true"/>
</EDITITEMTEMPLATE>
</ASP:
TEMPLATECOLUMN>
后台代码
protectedvoidCheckAll_CheckedChanged(objectsender,System.EventArgse)
{
//改变列的选定,实现全选或全不选。
CheckBoxchkExport;
if(CheckAll.Checked)
{
foreach(DataGridItemoDataGridIteminMyDataGrid.Items)
{
chkExport=(CheckBox)oDataGridItem.FindControl("chkExport");
chkExport.Checked=true;
}
}
else
{
foreach(DataGridItemoDataGridIteminMyDataGrid.Items)
{
chkExport=(CheckBox)oDataGridItem.FindControl("chkExport");
chkExport.Checked=false;
}
}
}17.数字格式化
【<%#Container.DataItem("price")%>的结果是500.0000,怎样格式化为500.00?
】
<%#Container.DataItem("price","{0:
¥#,##0.00}")%>
inti=123456;
strings=i.ToString("###,###.00");
18.日期格式化
【aspx页面内:
<%#DataBinder.Eval(Container.DataItem,"Company_Ureg_Date")%>
显示为:
2004-8-1119:
44:
28
我只想要:
2004-8-11】
<%#DataBinder.Eval(Container.DataItem,"Company_Ureg_Date","{0:
yyyy-M-d}")%>
应该如何改?
【格式化日期】
取出来,一般是object((DateTime)objectFromDB).ToString("yyyy-MM-dd");
【日期的验证表达式】
A.以下正确的输入格式:
[2004-2-29],[2004-02-2910:
29:
39pm],[2004/12/31]
^((\d{2}(([02468][048])|([13579][26]))[\-\/\s]?
((((0?
[13578])|(1[02]))[\-\/\s]?
((0?
[1-9])|([1-2][0-9])|(3[01])))|(((0?
[469])|(11))[\-\/\s]?
((0?
[1-9])|([1-2][0-9])|(30)))|(0?
2[\-\/\s]?
((0?
[1-9])|([1-2][0-9])))))|(\d{2}(([02468][1235679])|([13579][01345789]))[\-\/\s]?
((((0?
[13578])|(1[02]))[\-\/\s]?
((0?
[1-9])|([1-2][0-9])|(3[01])))|(((0?
[469])|(11))[\-\/\s]?
((0?
[1-9])|([1-2][0-9])|(30)))|(0?
2[\-\/\s]?
((0?
[1-9])|