asp.net程序中最常用的二十四种编程代码

本文分享了ASP.NET开发中的24种实用编程技巧,包括打开新窗口并传递参数、为按钮添加对话框、表格操作、日期格式化、异常处理等,帮助开发者提升工作效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

asp.net程序中最常用的二十四种编程代码
1 . 打开新的窗口并传送参数:  
  传送参数:   

response.write(
"<script>window.open(’*.aspx?id="+this.DropDownList1.SelectIndex+"&id1="+...+"’)</script>" )   

  接收参数:   

string a = Request.QueryString("id" );   
string b = Request.QueryString("id1" );   


2 .为按钮添加对话框  

Button1.Attributes.Add(
"onclick","return confirm(’确认?’)" );  
button.attributes.add(
"onclick","if(confirm(’are you sure...?’)){return true;}else{return false;}" )  

  
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;  
 }
  

}
  

6 .表格超连接列传递参数  

<asp:HyperLinkColumn Target
="_blank" headertext="ID号" DataTextField="id" NavigateUrl="aaa.aspx?id=’  
 <%# DataBinder.Eval(Container.DataItem, "数据字段1")%>’ & name=’<%# DataBinder.Eval(Container.DataItem, "数据字段2")%>’ / >  

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);  
  }
  
 }
  

  


12.Panel 横向滚动,纵向自动扩展  

<asp:panel style
="overflow-x:scroll;overflow-y:auto;"></asp:panel>  

13.回车转换成Tab  

<script language
="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>  

  

  


14.DataGrid超级连接列  

DataNavigateUrlField
="字段名" DataNavigateUrlFormatString="http://xx/inc/delete.aspx?ID={0}"  

15.DataGrid行随鼠标变色  

private void DGzf_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs 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=""+ "#EFF3F7"+""");  
 }
  
}
  

  


16.模板列  

<ASP:TEMPLATECOLUMN visible
="False" sortexpression="demo" headertext="ID">  
<ITEMTEMPLATE>  
<ASPABEL text
=’<%# DataBinder.Eval(Container.DataItem, "ArticleID")%>’ runat="server" width="80%" id="lblColumn" />  
/ITEMTEMPLATE>  
/ASP:TEMPLATECOLUMN>  

<ASP:TEMPLATECOLUMN headertext
="选中">  
<HEADERSTYLE wrap
="False" horiz></HEADERSTYLE>  
<ITEMTEMPLATE>  
<ASP:CHECKBOX id
="chkExport" runat="server" />  
/ITEMTEMPLATE>  
<EDITITEMTEMPLATE>  
<ASP:CHECKBOX id
="chkExportON" runat="server" enabled="true" />  
/EDITITEMTEMPLATE>  
/ASP:TEMPLATECOLUMN>  

  后台代码  

protected void CheckAll_CheckedChanged(object sender, System.EventArgs e)  
{  
 
//改变列的选定,实现全选或全不选。  
 CheckBox chkExport ;  
 
if( CheckAll.Checked)  
 
{  
  
foreach(DataGridItem oDataGridItem in MyDataGrid.Items)  
  
{  
   chkExport 
= (CheckBox)oDataGridItem.FindControl("chkExport");  
   chkExport.Checked 
= true;  
  }
  
 }
  
 
else  
 
{  
  
foreach(DataGridItem oDataGridItem in MyDataGrid.Items)  
  
{  
   chkExport 
= (CheckBox)oDataGridItem.FindControl("chkExport");  
   chkExport.Checked 
= false;  
  }
  
 }
  
}
  



18.日期格式化  

  【aspx页面内:<
%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date")%>  

  显示为: 
2004-8-11 19: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-29 10:29:39 pm], [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])|(1[0-9])|(2[0-8]))))))(s(((0?[1-9])|(1[0-2]))[0-5][0-9])((s)|([0-5][0-9])s))([AM|PM|am|pm]{2,2})))?$  

  B.以下正确的输入格式:[
0001-12-31], [9999 09 30], [2002/03/03]  

^d{4}[-/s]?((((0[13578])|(1[02]))[-/s]?(([0-2][0-9])|(3[01])))|(((0[469])|(11))[-/s]?(([0-2][0-9])|(30)))|(02[-/s]?[0-2][0-9]))$  

  【大小写转换】  

HttpUtility.HtmlEncode(
string);  
HttpUtility.HtmlDecode(
string)  

  



19.如何设定全局变量  

  Global.asax中  

  Application_Start()事件中  

  添加Application[属性名] = xxx;  

  就是你的全局变量  

  


20.怎样作到HyperLinkColumn生成的连接后,点击连接,打开新窗口?  

  HyperLinkColumn有个属性Target,将器值设置成
"_blank"即可.(Target="_blank")  

  【ASPNETMENU】点击菜单项弹出新窗口  

  在你的menuData.xml文件的菜单项中加入URLTarget
="_blank",如:  

?xml version="1.0" encoding="GB2312"?>  
<MenuData ImagesBaseURL
="images/">  
<MenuGroup>  
<MenuItem Label
="内参信息" URL="Infomation.aspx" >  
<MenuGroup ID
="BBC">  
<MenuItem Label
="公告信息" URL="Infomation.aspx" URLTarget="_blank" LeftIcon="file.gif"/>  
<MenuItem Label
="编制信息简报" URL="NewInfo.aspx" LeftIcon="file.gif" />  
......  

  最好将你的aspnetmenu升级到1.2版  


21.读取DataGrid控件TextBox值  

foreach(DataGrid dgi in yourDataGrid.Items)  
{  
 TextBox tb 
= (TextBox)dgi.FindControl("yourTextBoxId");  
 tb.Text....  
}
  

  


23.在DataGrid中有3个模板列包含Textbox分别为 DG_ShuLiang (数量) DG_DanJian(单价) DG_JinE(金额)分别在5.6.7列,要求在录入数量及单价的时候自动算出金额即:数量*单价=金额还要求录入时限制为 数值型.我如何用客户端脚本实现这个功能?  

  〖思归〗  

<asp:TemplateColumn HeaderText
="数量">  
<ItemTemplate>  
<asp:TextBox id
="ShuLiang" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>’  
.
/images/smilies/default/biggrin.gif" border=0 smilieid="3">oCal()"  
/>  

<asp:RegularExpressionValidator id
="revS" runat="server" C ErrorMessage="must be integer" Validati />  
/ItemTemplate>  
/asp:TemplateColumn>  

<asp:TemplateColumn HeaderText
="单价">  
<ItemTemplate>  
<asp:TextBox id
="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’  
.
/images/smilies/default/biggrin.gif" border=0 smilieid="3">oCal()"  
/>  

<asp:RegularExpressionValidator id
="revS2" runat="server" C ErrorMessage="must be numeric" Validati />  

/ItemTemplate>  
/asp:TemplateColumn>  

<asp:TemplateColumn HeaderText
="金额">  
<ItemTemplate>  
<asp:TextBox id
="JinE" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>’ />  
/ItemTemplate>  
/asp:TemplateColumn><script language="javascript">  
function DoCal()  
{  
 var e 
= event.srcElement;  
 var row 
= e.parentNode.parentNode;  
 var txts 
= row.all.tags("INPUT");  
 
if (!txts.length || txts.length < 3)  
  
return;  

 var q 
= txts[txts.length-3].value;  
 var p 
= txts[txts.length-2].value;  

 
if (isNaN(q) || isNaN(p))  
  
return;  

 q 
= parseInt(q);  
 p 
= parseFloat(p);  

 txts[txts.length
-1].value = (q * p).toFixed(2);  
}
  
/script>  

  



24.datagrid选定比较底下的行时,为什么总是刷新一下,然后就滚动到了最上面,刚才选定的行因屏幕的关系就看不到了。  

page_load  
page.smartNavigation
=true  
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值