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

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

 

 
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();
29.DataGrid使用:

  添加删除确认:
 private void DataGrid1_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
  {
  foreach(DataGridItem di in this.DataGrid1.Items)
   {
   if(di.ItemType==ListItemType.Item||di.ItemType==ListItemType.AlternatingItem)
    {
    ((LinkButton)di.Cells[8].Controls[0]).Attributes.Add("onclick","return confirm(’确认删除此项吗?’);");
   }
  }
 }
 
样式交替:
 ListItemType itemType = e.Item.ItemType;
 
 if (itemType == ListItemType.Item )
  {
  e.Item.Attributes["onmouseout"] = "javascript:this.style.backgroundColor=’#FFFFFF’;";
  e.Item.Attributes["onmouseover"] = "javascript:this.style.backgroundColor=’#d9ece1’;cursor=’hand’;" ;
 }
 else if( itemType == ListItemType.AlternatingItem)
  {
  e.Item.Attributes["onmouseout"] = "javascript:this.style.backgroundColor=’#a0d7c4’;";
  e.Item.Attributes["onmouseover"] = "javascript:this.style.backgroundColor=’#d9ece1’;cursor=’hand’;" ;
 }
 
添加一个编号列:
 DataTable dt= c.ExecuteRtnTableForAccess(sqltxt); //执行sql返回的DataTable
 DataColumn dc=dt.Columns.Add("number",System.Type.GetType("System.String"));
 
 for(int i=0;i<dt.Rows.Count;i++)
  {
  dt.Rows[i]["number"]=(i+1).ToString();
 }
 
 DataGrid1.DataSource=dt;
 DataGrid1.DataBind();
 

DataGrid1中添加一个CheckBox,页面中添加一个全选框
 private void CheckBox2_CheckedChanged(object sender, System.EventArgs e)
  {
  foreach(DataGridItem thisitem in DataGrid1.Items)
   {
   ((CheckBox)thisitem.Cells[0].Controls[1]).Checked=CheckBox2.Checked;
  }
 }
 
将当前页面中DataGrid1显示的数据全部删除
 foreach(DataGridItem thisitem in DataGrid1.Items)
  {
  if(((CheckBox)thisitem.Cells[0].Controls[1]).Checked)
   {
   string strloginid= DataGrid1.DataKeys[thisitem.ItemIndex].ToString();
   Del (strloginid); //删除函数
  }
 }
 
 30.当文件在不同目录下,需要获取数据库连接字符串(如果连接字符串放在Web.config,然后在Global.asax中初始化)
在Application_Start中添加以下代码:
 Application["ConnStr"]=this.Context.Request.PhysicalApplicationPath+ConfigurationSettings.
    AppSettings["ConnStr"].ToString();
 
31. 变量.ToString()

  字符型转换 转为字符串
 12345.ToString("n"); //生成 12,345.00
 12345.ToString("C"); //生成 ¥12,345.00
 12345.ToString("e"); //生成 1.234500e+004
 12345.ToString("f4"); //生成 12345.0000
 12345.ToString("x"); //生成 3039 (16进制)
 12345.ToString("p"); //生成 1,234,500.00%
 

32、变量.Substring(参数1,参数2);

  截取字串的一部分,参数1为左起始位数,参数2为截取几位。 如:string s1 = str.Substring(0,2);

  33.在自己的网站上登陆其他网站:(如果你的页面是通过嵌套方式的话,因为一个页面只能有一个FORM,这时可以导向另外一个页面再提交登陆信息)
 <SCRIPT language="javascript">
 <!--
  function gook(pws)
  {
   frm.submit();
  }
 //-->
 
 </SCRIPT> <body leftMargin="0" topMargin="0" οnlοad="javascript:gook()" marginwidth="0" marginheight="0">
 <form name="frm" action=" http://220.194.55.68:6080/login.php?retid=7259 " method="post">
 <tr>
 <td>
 <input id="f_user" type="hidden" size="1" name="f_user" runat="server">
 <input id="f_domain" type="hidden" size="1" name="f_domain" runat="server">
 <input class="box" id="f_pass" type="hidden" size="1" name="pwshow" runat="server">
 
 <INPUT id="lng" type="hidden" maxLength="20" size="1" value="5" name="lng">
 <INPUT id="tem" type="hidden" size="1" value="2" name="tem">
 
 </td>
 
 </tr>
 
 </form>
 

文本框的名称必须是你要登陆的网页上的名称,如果源码不行可以用vsniffer 看看。

  下面是获取用户输入的登陆信息的代码:
 string name;
 name=Request.QueryString["EmailName"];
 
 try
  {
  int a=name.IndexOf("@",0,name.Length);
  f_user.Value=name.Substring(0,a);
  f_domain.Value=name.Substring(a+1,name.Length-(a+1));
  f_pass.Value=Request.QueryString["Psw"];
 }
 
 catch
  {
  Script.Alert("错误的邮箱!");
  Server.Transfer("index.aspx");
 }

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值