1.为按钮添加确认对话框 Button1.Attributes.Add("onclick","return confirm(’确认?’)"); 2.删除表格选定记录 //获得DataGrid主键 3.删除表格记录警告 private void DataGrid_ItemCreated(Object sender,DataGridItemEventArgs e) 4.点击表格行链接另一页 private void grdCustomer_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) 5.双击表格连接到另一页 在itemDataBound事件中 if(e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem) 6.双击表格打开新一页 if(e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem) 7.表格超连接列传递参数 <asp:HyperLinkColumn Target="_blank" headertext="ID号" DataTextField="id" NavigateUrl="aaa.aspx?id=’ 8.表格点击改变颜色 if (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem) 9.在表格行中移动鼠标时改变颜色 写在DataGrid的_ItemDataBound里 if (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem) 10.关于日期格式 日期格式设定 DataFormatString="{0:yyyy-MM-dd}" 我觉得应该在itembound事件中 e.items.cell["你的列"].text=DateTime.Parse(e.items.cell["你的列"].text.ToString("yyyy-MM-dd")) 11.获取错误信息并到指定页面 不要使用Response.Redirect,而应该使用Server.Transfer e.g // in global.asax //其余的非HttpUnhandledException异常交给ASP.NET自己处理就okay了 :) Redirect会导致post-back的产生从而丢失了错误信息,所以页面导向应该直接在服务器端执行,这样就可以在错误处理页面得到出错信息并进行相应的处理。 12.清空Cookie Cookie.Expires=[DateTime]; 13.自定义异常处理 //自定义异常处理类 namespace MyAppException public AppException(string message) public AppException(string message,Exception innerException) //日志记录类 namespace MyEventLog /// <summary> /// <summary> /// <summary> /// <summary> EventLog eventLog = new EventLog("Application", ApplicationConfiguration.EventLogMachineName, ApplicationConfiguration.EventLogSourceName ); } 14.Panel 横向滚动,纵向自动扩展 <asp:panel style="overflow-x:scroll;overflow-y:auto;"></asp:panel> 15.回车转换成Tab <script language="javascript" for="document" event="onkeydown"> οnkeydοwn="if(event.keyCode==13) event.keyCode=9" 16.DataGrid超级连接列 DataNavigateUrlField="字段名" DataNavigateUrlFormatString=http://xx/inc/delete.aspx?ID={0} 17.DataGrid行随鼠标变色 private void DGzf_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) 18.模板列 <ASP:TEMPLATECOLUMN visible="False" sortexpression="demo" headertext="ID"> <ASP:TEMPLATECOLUMN headertext="选中"> 后台代码 protected void CheckAll_CheckedChanged(object sender, System.EventArgs e) 19.数字格式化 【<%#Container.DataItem("price")%>的结果是500.0000,怎样格式化为500.00?】 <%#Container.DataItem("price","{0:¥#,##0.00}")%> int i=123456; 20.日期格式化 【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})))?$ ^/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); 21.怎样作到HyperLinkColumn生成的连接后,点击连接,打开新窗口? HyperLinkColumn有个属性Target,将器值设置成"_blank"即可.(Target="_blank") 【ASPNETMENU】点击菜单项弹出新窗口 在你的menuData.xml文件的菜单项中加入URLTarget="_blank",如: <?xml version="1.0" encoding="GB2312"?> 22.读取DataGrid控件TextBox值 foreach(DataGrid dgi in yourDataGrid.Items) 23.在DataGrid中有3个模板列包含Textbox分别为 DG_ShuLiang (数量) DG_DanJian(单价) DG_JinE(金额)分别在5.6.7列,要求在录入数量及单价的时候自动算出金额即:数量*单价=金额还要求录入时限制为 数值型.我如何用客户端脚本实现这个功能? <asp:TemplateColumn HeaderText="数量"> <asp:RegularExpressionValidator id="revS" runat="server" ControlToValidate="ShuLiang" ErrorMessage="must be integer" ValidationExpression="^/d+$" /> <asp:TemplateColumn HeaderText="单价"> <asp:RegularExpressionValidator id="revS2" runat="server" ControlToValidate="DanJian" ErrorMessage="must be numeric" ValidationExpression="^/d+(/./d*)?$" /> </ItemTemplate> <asp:TemplateColumn HeaderText="金额"> var q = txts[txts.length-3].value; if (isNaN(q) || isNaN(p)) q = parseInt(q); txts[txts.length-1].value = (q * p).toFixed(2); 24.datagrid选定比较底下的行时,为什么总是刷新一下,然后就滚动到了最上面,刚才选定的行因屏幕的关系就看不到了。 page_load 25.在Datagrid中修改数据,当点击编辑键时,数据出现在文本框中,怎么控制文本框的大小 ? private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e) 26.对话框 private static string ScriptBegin = "<script language=/"JavaScript/">"; public static void ConfirmMessageBox(string PageTarget,string Content) ConfirmContent=ScriptBegin + ConfirmContent + ScriptEnd; Page ParameterPage = (Page)System.Web.HttpContext.Current.Handler; 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; //总页面数 下一页: if(DataGrid1.CurrentPageIndex < (DataGrid1.PageCount - 1)) bind(); // DataGrid1数据绑定函数 上一页: if(DataGrid1.CurrentPageIndex >0) bind(); // DataGrid1数据绑定函数 直接页面跳转: int a=int.Parse(JumpPage.Value.Trim());//JumpPage.Value.Trim()为跳转值 if(a<DataGrid1.PageCount) bind(); 29.DataGrid添加删除确认: private void DataGrid1_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) 30.DataGrid样式交替: ListItemType itemType = e.Item.ItemType; if (itemType == ListItemType.Item ) 31.DataGrid添添加一个编号列: DataTable dt= c.ExecuteRtnTableForAccess(sqltxt); //执行sql返回的DataTable for(int i=0;i<dt.Rows.Count;i++) DataGrid1.DataSource=dt; 32.DataGrid1中添加一个CheckBox,页面中添加一个全选框 private void CheckBox2_CheckedChanged(object sender, System.EventArgs e) 33.DataGrid添将当前页面中DataGrid1显示的数据全部删除 foreach(DataGridItem thisitem in DataGrid1.Items) 34.当文件在不同目录下,需要获取数据库连接字符串(如果连接字符串放在Web.config,然后在Global.asax中初始化) 在Application_Start中添加以下代码: Application["ConnStr"]=this.Context.Request.PhysicalApplicationPath+ConfigurationSettings. 35.变量.ToString() 字符型转换 转为字符串 12345.ToString("n"); //生成 12,345.00 36.在自己的网站上登陆其他网站:(如果你的页面是通过嵌套方式的话,因为一个页面只能有一个FORM,这时可以导向另外一个页面再提交登陆信息) <SCRIPT language="javascript"> </SCRIPT> <body leftMargin="0" topMargin="0" οnlοad=" gook()" marginwidth="0" marginheight="0"> 文本框的名称必须是你要登陆的网页上的名称,如果源码不行可以用vsniffer 看看。 下面是获取用户输入的登陆信息的代码: string name; try |
1、绑定在DataList中的DropDownList
private void dlistOrder_EditCommand(object source, System.Web.UI.WebControls.DataListCommandEventArgs e)
{
//绑定订单状态
for(int i=0;i<((DropDownList)dlistOrder.Items[e.Item.ItemIndex].FindControl("ddlFlag")).Items.Count;i++)
{
if(((DropDownList)dlistOrder.Items[e.Item.ItemIndex].FindControl("ddlFlag")).Items[i].Value == dv.Table.Rows[0]["OrStatus"].ToString())
{
((DropDownList)dlistOrder.Items[e.Item.ItemIndex].FindControl("ddlFlag")).Items[i].Selected = true;
}
}
}
2、另一种绑定方式
//绑定送货方式
DataView shipType = OrderSO.GetShipTypeList();
DropDownList ddlShipType = (DropDownList)dlistOrder.Items[e.Item.ItemIndex].FindControl("ddlShipType");
ddlShipType.DataSource = shipType;
ddlShipType.DataTextField = "StName";
ddlShipType.DataValueField = "StId";
ddlShipType.DataBind();
ddlShipType.SelectedIndex = ddlShipType.Items.IndexOf(ddlShipType.Items.FindByValue(dv.Table.Rows[0]["OrShipType"].ToString()));
3、在编辑嵌套在Datalist内的Datagrid某条记录时定位它所在的Datalist行
protected void MyList_ItemCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
{
if(e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
HtmlInputHidden odid = (HtmlInputHidden) e.Item.Cells[0].FindControl("odid");
DataListItem item = (DataListItem)e.Item.Parent.Parent.Parent;
DropDownList flag = (DropDownList)item.FindControl("ddlFlag");
if(flag.SelectedIndex == 0)
{
if(e.CommandName == "Delete")
{
int iOdId = Convert.ToInt32(odid.Value);
//删除订单明细方法
OrderSO.DeleteOrderDetail(iOdId);
}
}
else
{
GDCIC.Framework.Utility.MessageBox(this,"modifyError","经过确认的订单不能再修改!!");
return;
}
dlistOrder.EditItemIndex = -1;
BindData();
}
}
4、DataBinding绑定表达式:
1) 普通的绑定表达式
<%# DataBinder.Eval(Container.DataItem, "ContactName") %>
2) 文本+绑定表达式
<asp:Label id=lblDate runat="server" Text='<%# "[" + DataBinder.Eval(Container, "DataItem.NewsCreatedate") + "]" %>' ForeColor="Red"></asp:Label>
3) 同时带有显示格式的绑定表达式
<%# DataBinder.Eval(Container,"DataItem.USActiveDate","{0:yyyy-MM-dd}") %>
4) 结合绑定表达式和模态框
<A href='<%# ShowModalWin(Convert.ToString(DataBinder.Eval(Container.DataItem, "PictureImage")),Convert.ToString(DataBinder.Eval(Container.DataItem, "DetailID")),Convert.ToString(DataBinder.Eval(Container.DataItem, "PictureID")))%>'>
其中:后台代码文件中ShowModalWin()方法的定义如下:
protected string ShowModalWin(string PictureImage,string DetailID,string PictureID)
{
return " window.showModalDialog(/"Customers/ShowPictureInfo.aspx?pid="+PictureImage+"&did="+DetailID+"&id="+PictureID+"/",/"/",/"dialogHeight:320px;dialogWidth:480px;center:yes;help:no;status:no;scroll:no/");";
}
或者将参数提取出来单独定义成一变量:
const string WINDOWPARAMSTRING="dialogWidth:540px;dialogHeight:420px;help:0;status:0;resizeable:1;scroll:no";
Page.RegisterStartupScript("functionscript","<script language='javascript'>window.showModalDialog('EditUserService.aspx?URID="+iURID+"','','"+WINDOWPARAMSTRING+"')</script>");
5、在已有的数据集中添加一个新行
int iURID=int.Parse(Session[Globals.USER_ID_SESSION_NAME].ToString());
DataSet myds=UserSO.GetMapUserServiceToServiceList(iURID);
//增加一个邮件行
DataRow mydr = myds.Tables[0].NewRow();
mydr["SVHref"] = "http://211.155.23.77";
mydr["SVName"] = "政务邮箱";
mydr["USEndDate"] = System.DateTime.Now.AddDays(1);
myds.Tables[0].Rows.Add(mydr);
DataView mydv=myds.Tables[0].DefaultView;
if(myds.Tables[0].Rows.Count!=0)
{
mydv.RowFilter=" USEndDate>'"+System.DateTime.Now+"'";// 没过期
dgUserService.Visible=true;
dgUserService.DataSource =mydv;
try
{
dgUserService.DataBind();
}
catch
{
dgUserService.CurrentPageIndex =dgUserService.PageCount -1;
dgUserService.DataBind();
}
}
else
{
dgUserService.Visible=false;
}
6、加入客户端验证控件
//验证空值
<asp:requiredfieldvalidator id="valUsername" runat="server" controltovalidate="txtUsername" display="None" errormessage="请输入用户名 !!"></asp:requiredfieldvalidator>
//验证网址
<asp:regularexpressionvalidator id="rev" runat="server" ErrorMessage="公司网址不合法[要有http://] !" Display="None" ControlToValidate="txtCPWebsite" ValidationExpression="http://([/w-]+/.)+[/w-]+(/[/w- ./?%&=]*)?"></asp:regularexpressionvalidator>
//验证邮箱
<asp:RequiredFieldValidator id="rfv" runat="server" ControlToValidate="txtCPEmail" Display="None" ErrorMessage="请输入电子邮箱 !!"></asp:RequiredFieldValidator>
//验证邮编
<asp:regularexpressionvalidator id="rev5" runat="server" ErrorMessage="邮政编码不合法 !" Display="None" ControlToValidate="txtCPPostCode" ValidationExpression="/d{6}"></asp:regularexpressionvalidator>
//显示错误信息
<asp:validationsummary id="vs" runat="server" ShowSummary="False" ShowMessageBox="True"></asp:validationsummary>
7、枚举类型的使用
1) 定义:
public enum UserTypeEnum:byte
{
/// <summary>
/// 个人用户
/// </summary>
Individual = 0,
/// <summary>
/// 单位用户
/// </summary>
Corporation = 1
}
2) 在代码中的使用方法:
UserTypeEnum ut = UserTypeEnum.Corporation;
GDCIC.Entities.UserVO userVO = GDCIC.Facade.UserSO.GetUserVO(urid);
ut = (UserTypeEnum)Enum.Parse(UserTypeEnum.Corporation.GetType(),userVO.URUserType);
if (ut == UserTypeEnum.Corporation)
{
... ...
}
//直接获得其代表的值的方法
Response.Write("枚举值为:"+Convert.ToInt32(UserTypeEnum.Individual));
8、验证用户名必须以字母打头且不能含有中文
String sUsername = txtUsername.Text.Trim();
if(!Regex.IsMatch(sUsername, "^[A-Za-z].*"))
{
Utility.MessageBox(this,"nameFormatError","用户名要以字母开头, 且不要用中文名称 !!");
return;
}
9、如何在删除并重新安装 IIS 之后修复 IIS 映射
运行 Aspnet_regiis.exe 实用工具:
1、
- 单击“开始”,然后单击“运行”。
- 在“打开”框中,键入 cmd,然后按 Enter 键。
- 在命令提示符下键入以下命令,然后按 Enter 键:
"%windir%/Microsoft.NET/Framework/版本/aspnet_regiis.exe" -i
2、在此路径中,版本代表在服务器上安装的 .NET Framework 的版本号。键入此命令时,必须将此占位符替换为实际版本号。
- 注册 Aspnet_isapi.dll;
- 单击“开始”,然后单击“运行”。
- 在“打开”文本框中,键入以下内容,然后按 Enter 键:
regsvr32 %windir%/Microsoft.NET/Framework/版本/aspnet_isapi.dll
Regsvr32 将返回注册结果。
10、下载文件的方法:
Response.AppendHeader("content-disposition", "attachment; filename=" + Request.Params("link").ToString)
Response.ContentType = Request.Params("contenttype").ToString
Response.WriteFile(strLink)
Response.End()
可从数据中读出文件名称,直接指定到服务器的路径下即可,所以要求上传文件时`需求指定文件在服务器上保存的路径。
对于此方法,需要重定向到一个页面,此页面负责处理文件的写入。参数contenttype可以选择写或不写,在明确的情况下,最好写入。
但appendheader必须写明,最后调用WriteFile将文件输出,用到的路径是相对路径。
11、如何在动态加载控件时,让客户端脚本起作用
event.srcElement,可以得到事件引发者对象。对于要求引用多个对象时,可以用一变量将控件值保存起来。
方法如下:
Response.Write("<input type=/"hidden/" id=/"jjj/" value="+this.ClientID+">");
注:此处此控件的ID号为固定值。
12、如何在IIS上注册aspnet
aspnet_regIIS -i
13、Server对象
1) Server.Transfer: 转到另一页面,但没有向浏览器发送任何信息,当用户刷新时,将刷新的是重定向之前的那一页。
2) Server.Execute: 执行另一页面的请求,执行之后返回原来的页面。
14、禁用请求验证的方法
请求验证过程检测到有潜在危险的客户端输入值,对请求的处理已经中止。该值可能指示危及应用程序安全的尝试,如跨站点的脚本攻击。通过在 Page 指令或 配置节中设置 validateRequest=false 可以禁用请求验证。但是,在这种情况下,强烈建议应用程序显式检查所有输入。
如:<system.web>
<pages ValidateRequest="false" />
</system.web>