代码改变世界

ASP.NET Web开发实用代码(三)

2008-12-26 16:17  TTlive  阅读(157)  评论(0编辑  收藏  举报

1.读取DataGrid控件TextBox值

  1. foreach(DataGrid dgi in yourDataGrid.Items)
  2. {
  3.     TextBox tb = (TextBox)dgi.FindControl("yourTextBoxId");
  4.     tb.Text....
  5. } 

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

  1. <asp:TemplateColumn HeaderText="数量"> 
  2. <ItemTemplate>
  3. <asp:TextBox id="ShuLiang" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>’ 
  4. />
  5. <asp:RegularExpressionValidator id="revS" runat="server" C ErrorMessage="must be integer" Validati />
  6. </ItemTemplate>
  7. </asp:TemplateColumn>
  8. <asp:TemplateColumn HeaderText="单价"> 
  9. <ItemTemplate>
  10. <asp:TextBox id="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’ 
  11. />
  12. <asp:RegularExpressionValidator id="revS2" runat="server" C ErrorMessage="must be numeric" Validati />
  13. </ItemTemplate>
  14. </asp:TemplateColumn>
  15. <asp:TemplateColumn HeaderText="金额"> 
  16. <ItemTemplate>
  17. <asp:TextBox id="JinE" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>’ />
  18. </ItemTemplate>
  19. </asp:TemplateColumn>
  20. <script language="javascript">
  21. function DoCal()
  22. {
  23. var e = event.srcElement;
  24. var row = e.parentNode.parentNode;
  25. var txts = row.all.tags("INPUT");
  26. if (!txts.length || txts.length < 3)
  27. return;
  28. var q = txts[txts.length-3].value;
  29. var p = txts[txts.length-2].value;
  30. if (isNaN(q) || isNaN(p))
  31. return;
  32. q = parseInt(q);
  33. p = parseFloat(p);
  34. txts[txts.length-1].value = (q * p).toFixed(2);
  35. }
  36. </script>

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

  1. page_load 
  2. page.smartNavigation=true

4.在Datagrid中修改数据,当点击编辑键时,数据出现在文本框中,怎么控制文本框的大小?

  1. private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e)
  2. {
  3.     for(int i=0;i<e.Item.Cells.Count-1;i++)
  4.     if(e.Item.ItemType==ListItemType.EditType)
  5.     {
  6.         e.Item.Cells.Attributes.Add("Width""80px")
  7.     } 
  8. } 

5.对话框

  1. private static string ScriptBegin = "<script language=/"JavaScript/">";
  2. private static string ScriptEnd = "</script>";
  3. public static void ConfirmMessageBox(string PageTarget,string Content)
  4. {
  5.     string C+Content+"');"+"if(retValue){window.location='"+PageTarget+"';}";
  6.     ConfirmContent=ScriptBegin + ConfirmContent + ScriptEnd;
  7.     Page ParameterPage = (Page)System.Web.HttpContext.Current.Handler;
  8.     ParameterPage.RegisterStartupScript("confirm",ConfirmContent);
  9.     //Response.Write(strScript);
  10. }

6.将时间格式化:string aa=DateTime.Now.ToString("yyyy年MM月dd日");

取当前年月日时分秒:

  1. currentTime=System.DateTime.Now;

取当前年:

  1. int 年= DateTime.Now.Year;

取当前月:

  1. int 月= DateTime.Now.Month; 

取当前日:

  1. int 日= DateTime.Now.Day; 

取当前时:

  1. int 时= DateTime.Now.Hour; 

取当前分:

  1. int 分= DateTime.Now.Minute; 

取当前秒:

  1. int 秒= DateTime.Now.Second; 

取当前毫秒:

  1. int 毫秒= DateTime.Now.Millisecond; 

7.自定义分页代码:

先定义变量 :

  1. public static int pageCount; //总页面数 
  2. public static int curPageIndex=1; //当前页面 
  3. //下一页: 
  4. if(DataGrid1.CurrentPageIndex < (DataGrid1.PageCount - 1)) { 
  5.     DataGrid1.CurrentPageIndex += 1; 
  6.     curPageIndex+=1; 
  7. bind(); // DataGrid1数据绑定函数 
  8. //上一页: 
  9. if(DataGrid1.CurrentPageIndex >0) { 
  10.     DataGrid1.CurrentPageIndex += 1; 
  11.     curPageIndex-=1; 
  12. bind(); // DataGrid1数据绑定函数 
  13. //直接页面跳转: 
  14. int a=int.Parse(JumpPage.Value.Trim());//JumpPage.Value.Trim()为跳转值 
  15. if(a<DataGrid1.PageCount) { 
  16.     this.DataGrid1.CurrentPageIndex=a; 
  17. bind();

8.DataGrid使用:

添加删除确认:

  1. private void DataGrid1_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) 
  2.     foreach(DataGridItem di in this.DataGrid1.Items) { 
  3.         if(di.ItemType==ListItemType.Item||di.ItemType==ListItemType.AlternatingItem) { 
  4.             ((LinkButton)di.Cells[8].Controls[0]).Attributes.Add("onclick","return confirm('确认删除此项吗?');"); 
  5.         } 
  6.     } 
  7. }

样式交替:

  1. ListItemType itemType = e.Item.ItemType; 
  2. if (itemType == ListItemType.Item ) { 
  3.     e.Item.Attributes["onmouseout"] = "javascript:this.style.backgroundColor='#FFFFFF';"
  4.     e.Item.Attributes["onmouseover"] = "javascript:this.style.backgroundColor='#d9ece1';cursor='hand';" ; 
  5. else if( itemType == ListItemType.AlternatingItem) { 
  6.     e.Item.Attributes["onmouseout"] = "javascript:this.style.backgroundColor='#a0d7c4';"
  7.     e.Item.Attributes["onmouseover"] = "javascript:this.style.backgroundColor='#d9ece1';cursor='hand';" ; 
  8. }

添加一个编号列:

  1. DataTable dt= c.ExecuteRtnTableForAccess(sqltxt); //执行sql返回的DataTable 
  2. DataColumn dc=dt.Columns.Add("number",System.Type.GetType("System.String")); 
  3. for(int i=0;i<dt.Rows.Count;i++) {
  4.     dt.Rows["number"]=(i+1).ToString(); 
  5. DataGrid1.DataSource=dt; 
  6. DataGrid1.DataBind(); 
  7. //DataGrid1中添加一个CheckBox,页面中添加一个全选框 
  8. private void CheckBox2_CheckedChanged(object sender, System.EventArgs e) {
  9.     foreach(DataGridItem thisitem in DataGrid1.Items) { 
  10.         ((CheckBox)thisitem.Cells[0].Controls[1]).Checked=CheckBox2.Checked; 
  11.     } 
  12. }

将当前页面中DataGrid1显示的数据全部删除

  1. foreach(DataGridItem thisitem in DataGrid1.Items) {
  2.     if(((CheckBox)thisitem.Cells[0].Controls[1]).Checked) { 
  3.         string strloginid= DataGrid1.DataKeys[thisitem.ItemIndex].ToString(); 
  4.         Del (strloginid); //删除函数 
  5.     } 
  6. }

9.当文件在不同目录下,需要获取数据库连接字符串(如果连接字符串放在Web.config,然后在Global.asax中初始化)

在Application_Start中添加以下代码:

  1. Application["ConnStr"]=this.Context.Request.PhysicalApplicationPath+ConfigurationSettings.
  2. AppSettings["ConnStr"].ToString(); 

10.变量.ToString()

字符型转换 转为字符串

  1. 12345.ToString("n"); //生成 12,345.00 
  2. 12345.ToString("C"); //生成 ¥12,345.00 
  3. 12345.ToString("e"); //生成 1.234500e+004 
  4. 12345.ToString("f4"); //生成 12345.0000 
  5. 12345.ToString("x"); //生成 3039 (16进制) 
  6. 12345.ToString("p"); //生成 1,234,500.00% 

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

截取字串的一部分,参数1为左起始位数,参数2为截取几位。 如:

  1. string s1 = str.Substring(0,2); 

12.在自己的网站上登陆其他网站:(如果你的页面是通过嵌套方式的话,因为一个页面只能有一个FORM,这时可以导向另外一个页面再提交登陆信息)

  1. <SCRIPT language="javascript"> 
  2. <!-- 
  3. function gook(pws) 
  4.     frm.submit(); 
  5. //--> 
  6. </SCRIPT> <body leftMargin="0" topMargin="0"  marginwidth="0" marginheight="0"> 
  7. <form name="frm" action=" http://www.xxx.com " method="post"> 
  8. <tr> 
  9. <td>
  10. <input id="f_user" type="hidden" size="1" name="f_user" runat="server">
  11. <input id="f_domain" type="hidden" size="1" name="f_domain" runat="server">
  12. <input class="box" id="f_pass" type="hidden" size="1" name="pwshow" runat="server"> 
  13. <INPUT id="lng" type="hidden" maxLength="20" size="1" value="5" name="lng">
  14. <INPUT id="tem" type="hidden" size="1" value="2" name="tem"> 
  15. </td> 
  16. </tr> 
  17. </form>

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

下面是获取用户输入的登陆信息的代码:

  1. string name; 
  2. name=Request.QueryString["EmailName"]; 
  3. try 
  4.     int a=name.IndexOf("@",0,name.Length); 
  5.     f_user.Value=name.Substring(0,a); 
  6.     f_domain.Value=name.Substring(a+1,name.Length-(a+1)); 
  7.     f_pass.Value=Request.QueryString["Psw"]; 
  8. catch 
  9.     Script.Alert("错误的邮箱!"); 
  10.     Server.Transfer("index.aspx"); 
  11. }

13.datagrid分页中如果删除时出现超出索引

  1. public void jumppage(System.Web.UI.WebControls.DataGrid dg) { 
  2.     int int_PageLess; //定义页面跳转的页数 
  3.     //如果当前页是最后一页 
  4.     if(dg.CurrentPageIndex == dg.PageCount-1) { 
  5.         //如果就只有一页 
  6.         if(dg.CurrentPageIndex == 0) { 
  7.             //删除后页面停在当前页 
  8.             dg.CurrentPageIndex = dg.PageCount-1; 
  9.         } 
  10.         else { 
  11.             //如果最后一页只有一条记录 
  12.             if((dg.Items.Count % dg.PageSize == 1) || dg.PageSize == 1) { 
  13.                 //把最后一页最后一条记录删除后,页面应跳转到前一页 
  14.                 int_PageLess = 2; 
  15.             } 
  16.             else //如果最后一页的记录数大于1,那么在最后一页删除记录后仍然停在当前页 { 
  17.                 int_PageLess = 1; 
  18.             } 
  19.             dg.CurrentPageIndex = dg.PageCount - int_PageLess; 
  20.         } 
  21.     } 
  22. }

14.警告窗口

  1. /// 服务器端弹出alert对话框 
  2. ///  
  3. /// 提示信息,例子:"不能为空!" 
  4. /// Page类 
  5. public void Alert(string str_Message,Page page) { 
  6.     page.RegisterStartupScript("",""); 

15.重载此警告窗口,使某控件获得焦点

  1. /// 服务器端弹出alert对话框,并使控件获得焦点 
  2. ///  
  3. /// 获得焦点控件Id值,比如:txt_Name 
  4. /// 提示信息,例子:"请输入您姓名!" 
  5. /// Page类 
  6. public void Alert(string str_Ctl_Name,string str_Message,Page page) { 
  7.     page.RegisterStartupScript("",""); 
  8. }

16.确认对话框

  1. /// 服务器端弹出confirm对话框 
  2. ///  
  3. /// 提示信息,例子:"您是否确认删除!" 
  4. /// 隐藏Botton按钮Id值,比如:btn_Flow 
  5. /// Page类 
  6. public void Confirm(string str_Message,string btn,Page page) { 
  7.     page.RegisterStartupScript("",""); 
  8. }