ASP.NET程序中常用的三十三种代码(1)

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


}

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 + "’)");
}

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会导致post-back的产生从而丢失了错误信息,所以页面导向应该直接在服务器端执行,这样就可以在错误处理页面得到出错信息并进行相应的处理
10.清空Cookie
Cookie.Expires = [DateTime];
Response.Cookies(
" UserName " ).Expires  =   0
  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")%>’ 
οnkeyup="javascript:DoCal()"
/>

<asp:RegularExpressionValidator id="revS" runat="server" ControlToValidate="ShuLiang" ErrorMessage="must be integer" ValidationExpression="^/d+$" />
</ItemTemplate>
</asp:TemplateColumn>

<asp:TemplateColumn HeaderText="单价"> 
<ItemTemplate>
<asp:TextBox id="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’ 
οnkeyup="javascript:DoCal()"
/>

<asp:RegularExpressionValidator id="revS2" runat="server" ControlToValidate="DanJian" ErrorMessage="must be numeric" ValidationExpression="^/d+(/./d*)?$" />

</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
  25.在Datagrid中修改数据,当点击编辑键时,数据出现在文本框中,怎么控制文本框的大小 ?
private   void  DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e)
{
 
for(int i=0;i<e.Item.Cells.Count-1;i++)
  
if(e.Item.ItemType==ListItemType.EditType)
  
{
   e.Item.Cells[i].Attributes.Add(
"Width""80px")
  }
 
}


26.对话框
private   static   string  ScriptBegin  =   " <script language=/ " JavaScript/ " " ;
private   static   string  ScriptEnd  =   " </script> " ;

public   static   void  ConfirmMessageBox( string  PageTarget, string  Content)
{
 
string ConfirmContent="var retValue=window.confirm(’"+Content+"’);"+"if(retValue){window.location=’"+PageTarget+"’;}";

 ConfirmContent
=ScriptBegin + ConfirmContent + ScriptEnd;

 Page ParameterPage 
= (Page)System.Web.HttpContext.Current.Handler;
 ParameterPage.RegisterStartupScript(
"confirm",ConfirmContent);
 
//Response.Write(strScript);
}


27. 将时间格式化:string aa=DateTime.Now.ToString("yyyy年MM月dd日");
1.1 取当前年月日时分秒
currentTime = System.DateTime.Now;

 1.2 取当前年
int  年 =  DateTime.Now.Year;
1.3 取当前月
int  月 =  DateTime.Now.Month; 

 1.4 取当前日
int  日 =  DateTime.Now.Day; 
1.5 取当前时
int  时 =  DateTime.Now.Hour; 
1.6 取当前分
int  分 =  DateTime.Now.Minute; 
 1.7 取当前秒
int  秒 =  DateTime.Now.Second; 

 1.8 取当前毫秒
int  毫秒 =  DateTime.Now.Millisecond; 
28.自定义分页代码:
先定义变量 :
public   static   int  pageCount;  // 总页面数 
public   static   int  curPageIndex = 1 // 当前页面 
下一页:
if (DataGrid1.CurrentPageIndex < (DataGrid1.PageCount  -   1 )) 

 DataGrid1.CurrentPageIndex 
+= 1
 curPageIndex
+=1
}
 

bind(); 
//  DataGrid1数据绑定函数 

上一页:
if (DataGrid1.CurrentPageIndex > 0

 DataGrid1.CurrentPageIndex 
+= 1
 curPageIndex
-=1
}
 

bind(); 
//  DataGrid1数据绑定函数 

直接页面跳转:
int  a = int .Parse(JumpPage.Value.Trim()); // JumpPage.Value.Trim()为跳转值 

if (a<DataGrid1.PageCount) 

 
this.DataGrid1.CurrentPageIndex=a; 
}
 

bind(); 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值