0. ใช้เซสชันเพื่อพิจารณาว่าจะเข้าสู่ระบบ
หรือไม่ (เซสชัน ["เข้าสู่ระบบ"] == null)
-
Response.Redirect("error.aspx");
}
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('Confirm?')");
button.attributes.add("onclick","if(confirm('are you Sure .. .?')){ส่งคืนจริง;}else{ส่งคืนเท็จ;}")
3. ลบบันทึกที่เลือกในตาราง
int intEmpID = (int)MyDataGrid.DataKeys[e.Item.ItemIndex];
string DeleteCmd = "DELETE from Employee โดยที่ emp_id = " + intEmpID.ToString()
4. ลบคำเตือนบันทึกตาราง
โมฆะส่วนตัว DataGrid_ItemCreated (ผู้ส่งวัตถุ DataGridItemEventArgs e)
-
สวิตช์ (e.Item.ItemType)
-
กรณี ListItemType.Item :
กรณี ListItemType.AlternatingItem :
กรณี ListItemType.EditItem:
ตารางเซลล์ myTableCell;
myTableCell = e.Item.Cells[14];
LinkButton myDeleteButton;
myDeleteButton = (LinkButton)myTableCell.Controls[0];
myDeleteButton.Attributes.Add("onclick","return ยืนยัน('คุณแน่ใจหรือไม่ว่าต้องการลบข้อความนี้');");
หยุดพัก;
ค่าเริ่มต้น:
หยุดพัก;
}
}
5. คลิกแถวของตารางเพื่อเชื่อมโยงไปยังหน้าอื่น
เป็นโมฆะส่วนตัว grdCustomer_ItemDataBound(ผู้ส่งวัตถุ, System.Web.UI.WebControls.DataGridItemEventArgs e)
-
//คลิกแบบฟอร์มเพื่อเปิด
ถ้า (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
ถ้า (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
-
สตริง OrderItemID =e.item.cells[1].Text;
-
e.item.Attributes.Add("ondblclick", "location.href='../ShippedGrid.aspx?id=" + OrderItemID + "'");
-
ดับเบิลคลิกที่ตารางเพื่อเปิดหน้าใหม่
ถ้า (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
-
สตริง OrderItemID =e.item.cells[1].Text;
-
e.item.Attributes.Add("ondblclick", "open('../ShippedGrid.aspx?id=" + OrderItemID + "')");
-
★หมายเหตุพิเศษ: [?id=] ไม่สามารถเป็น [?id =]
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. คลิกที่ตารางเพื่อเปลี่ยนสี
ถ้า (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem)
-
e.Item.Attributes.Add("onclick","this.style.พื้นหลังสี='#99cc00';this.style.color='buttontext';this.style.cursor='default';");
-
เขียนใน _ItemDataBound ของ DataGrid
ถ้า (e.Item.ItemType == ListItemType.Item ||e.Item.ItemType == ListItemType.AlternatingItem)
-
e.Item.Attributes.Add("onmouseover", "this.style.พื้นหลังสี='#99cc00';this.style.color='buttontext';
this.style.cursor='default';");
e.Item.Attributes.Add("onmouseout","this.style.พื้นหลังสี='';this.style.color='';");
}
8. เกี่ยวกับ
การตั้งค่ารูปแบบ
วันที่ของรูปแบบวันที่
DataFormatString="{0:yyyy-MM-dd}"
ฉันคิดว่าควรอยู่ในเหตุการณ์ itembound
e.items.cell["your column"].text=DateTime.Parse(e.items.cell["your column"].text.ToString("yyyy-MM-dd"))
9. รับข้อมูลข้อผิดพลาด อย่า ใช้ Response.Redirect ไปยังเพจที่ระบุ แต่ใช้ Server.Transfer
เช่น
// ใน global.asax
ป้องกันโมฆะ Application_Error (ผู้ส่งวัตถุ EventArgs e) {
ถ้า (Server.GetLastError() คือ HttpUnhandledException)
Server.Transfer("MyErrorPage.aspx");
//ไม่เป็นไรที่จะปล่อยให้ข้อยกเว้นที่ไม่ใช่ HttpUnhandledException ที่เหลือไปที่ ASP.NET เอง :)
}
การเปลี่ยนเส้นทางจะทำให้เกิดการโพสต์ย้อนกลับและข้อมูลข้อผิดพลาดจะหายไป ดังนั้นคำแนะนำหน้าควรดำเนินการโดยตรงบนฝั่งเซิร์ฟเวอร์ เพื่อให้สามารถรับข้อมูลข้อผิดพลาดบนหน้าการจัดการข้อผิดพลาดและประมวลผลตามนั้น
10.ล้างคุกกี้
Cookie.Expires=[วันที่และเวลา];
Response.Cookies("ชื่อผู้ใช้").Expires = 0
11. การจัดการข้อยกเว้นแบบกำหนดเอง
// คลาสการจัดการข้อยกเว้นแบบกำหนดเอง
ใช้ระบบ;
ใช้ System.Diagnostics;
เนมสเปซ MyAppException
-
/// <สรุป>
/// คลาสการจัดการข้อยกเว้นของแอปพลิเคชันสืบทอดมาจากคลาสข้อยกเว้นของระบบ ApplicationException
/// บันทึกเนื้อหาข้อยกเว้นลงในบันทึกแอปพลิเคชันของ Windows NT/2000 โดยอัตโนมัติ
/// </สรุป>
AppException คลาสสาธารณะ: System.ApplicationException
-
publicAppException()
-
ถ้า (ApplicationConfiguration.EventLogEnabled)
LogEvent("เกิดข้อผิดพลาดที่ไม่ทราบสาเหตุ");
}
AppException สาธารณะ (ข้อความสตริง)
-
LogEvent(ข้อความ);
}
AppException สาธารณะ (ข้อความสตริง ข้อยกเว้น InnerException)
-
LogEvent(ข้อความ);
ถ้า (innerException != null)
-
LogEvent(ข้อความภายในข้อยกเว้น);
-
}
//คลาสการบันทึก
ใช้ระบบ;
โดยใช้ระบบการกำหนดค่า;
โดยใช้ระบบการวินิจฉัย
ใช้ System.IO;
ใช้ System.Text;
ใช้ System.Threading;
เนมสเปซ MyEventLog
-
/// <สรุป>
/// คลาสการบันทึกเหตุการณ์ ซึ่งให้การสนับสนุนการบันทึกเหตุการณ์
/// <หมายเหตุ>
/// กำหนดวิธีการบันทึก 4 วิธี (ข้อผิดพลาด คำเตือน ข้อมูล ติดตาม)
/// </หมายเหตุ>
/// </สรุป>
ApplicationLog คลาสสาธารณะ
-
/// <สรุป>
/// บันทึกข้อมูลข้อผิดพลาดลงในบันทึกเหตุการณ์ Win2000/NT
/// <param name="message">ข้อมูลข้อความที่จะบันทึก</param>
/// </สรุป>
โมฆะสาธารณะคง WriteError (ข้อความสตริง)
{
WriteLog (TraceLevel.Error, ข้อความ);
}
/// <สรุป>
/// บันทึกข้อมูลคำเตือนลงในบันทึกเหตุการณ์ Win2000/NT
/// <param name="message">ข้อมูลข้อความที่จะบันทึก</param>
/// </สรุป>
โมฆะสาธารณะคง WriteWarning (ข้อความสตริง)
{
WriteLog (TraceLevel.Warning, ข้อความ);
}
/// <สรุป>
/// บันทึกข้อมูลพรอมต์ลงในบันทึกเหตุการณ์ Win2000/NT
/// <param name="message">ข้อมูลข้อความที่จะบันทึก</param>
/// </สรุป>
โมฆะสาธารณะคง WriteInfo (ข้อความสตริง)
-
WriteLog (TraceLevel.Info, ข้อความ);
-
/// <สรุป>
/// บันทึกข้อมูลการติดตามลงในบันทึกเหตุการณ์ Win2000/NT
/// <param name="message">ข้อมูลข้อความที่จะบันทึก</param>
/// </สรุป>
โมฆะสาธารณะคง WriteTrace (ข้อความสตริง)
{
WriteLog (TraceLevel.Verbose, ข้อความ);
}
/// <สรุป>
/// จัดรูปแบบรูปแบบข้อมูลข้อความที่บันทึกไว้ในบันทึกเหตุการณ์
/// <param name="ex">วัตถุข้อยกเว้นที่ต้องจัดรูปแบบ</param>
/// <param name="catchInfo">สตริงชื่อข้อมูลข้อยกเว้น</param>
/// <มูลค่าเพิ่ม>
/// <para>สตริงข้อมูลข้อยกเว้นที่จัดรูปแบบ รวมถึงเนื้อหาข้อยกเว้นและสแต็กการติดตาม</para>
/// </มูลค่าใหม่>
/// </สรุป>
สาธารณะ FormatException สตริงคงที่ (ข้อยกเว้น เช่น สตริง catchInfo)
-
StringBuilder strBuilder = StringBuilder ใหม่ ();
ถ้า (catchInfo != String.Empty)
-
strBuilder.Append(catchInfo).Append("rn");
-
strBuilder.Append(ex.Message).Append("rn").Append(ex.StackTrace);
กลับ strBuilder.ToString();
}
/// <สรุป>
/// วิธีการเขียนบันทึกเหตุการณ์จริง
/// <param name="level">ระดับของข้อมูลที่จะบันทึก (ข้อผิดพลาด คำเตือน ข้อมูล ติดตาม)</param>
/// <param name="messageText">ข้อความที่จะบันทึก</param>
/// </สรุป>
โมฆะส่วนตัวคงที่ WriteLog (ระดับ TraceLevel, String messageText)
{
พยายาม
-
EventLogEntryType ประเภทรายการบันทึก;
สวิตช์ (ระดับ)
-
กรณี TraceLevel ข้อผิดพลาด:
LogEntryType = EventLogEntryType.Error;
หยุดพัก;
กรณี TraceLevel คำเตือน:
LogEntryType = EventLogEntryType.Warning;
หยุดพัก;
กรณี TraceLevel ข้อมูล:
LogEntryType = EventLogEntryType.Information;
หยุดพัก;
กรณี TraceLevel.รายละเอียด:
LogEntryType = EventLogEntryType.SuccessAudit;
หยุดพัก;
ค่าเริ่มต้น:
LogEntryType = EventLogEntryType.SuccessAudit;
หยุดพัก;
}
EventLog eventLog = EventLog ใหม่ ("Application", ApplicationConfiguration.EventLogMachineName, ApplicationConfiguration.EventLogSourceName );
//เขียนบันทึกเหตุการณ์
eventLog.WriteEntry(ข้อความ, LogEntryType);
}
catch {} // ละเว้นข้อยกเว้นใด ๆ
-
} //คลาส ApplicationLog
-
12.แผงเลื่อนในแนวนอนและขยายในแนวตั้งโดยอัตโนมัติ
<asp:panel style="overflow-x:scroll;overflow-y:auto;"></asp:panel>
13. แปลง Enter เป็น 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');
เหตุการณ์ keyCode=9;
</script>
onkeydown="if(event.keyCode==13) event.keyCode=9"
http://dotnet.aspx.cc/exam/enter2tab.aspx
14.คอลัมน์การเชื่อมต่อ DataGrid super
DataNavigateUrlField="ชื่อฟิลด์" DataNavigateUrlFormatString=" http://xx/inc/delete.aspx?ID={0 }"
15.แถว DataGrid เปลี่ยนสีด้วยเมาส์
โมฆะส่วนตัว DGzf_ItemDataBound (ผู้ส่งวัตถุ System.Web.UI.WebControls.DataGridItemEventArgs e)
-
ถ้า (e.Item.ItemType!=ListItemType.Header)
-
e.Item.Attributes.Add( "onmouseout", "this.style.พื้นหลังสี=""+e.Item.Style["พื้นหลัง-สี"]+""");
e.Item.Attributes.Add( "onmouseover", "this.style.พื้นหลังสี=""+ "#EFF3F7"+""");
}
}
16. คอลัมน์เทมเพลต
<ASP:TEMPLATECOLUMN มองเห็นได้ = "เท็จ" sortexpression = "สาธิต" headertext = "ID">
<เทมเพลตรายการ>
<ASP:LABEL text='<%# DataBinder.Eval(Container.DataItem, "ArticleID")%>' runat = "เซิร์ฟเวอร์" width = "80%" id = "lblColumn" />
</รายการเทมเพลต>
</ASP:เทมเพลตคอลัมน์>
<ASP:TEMPLATECOLUMN headertext="ตรวจสอบ">
<HEADERSTYLE wrap="False"horizontalalign="Center"></HEADERSTYLE>
<เทมเพลตรายการ>
<ASP:CHECKBOX id = "chkExport" runat = "เซิร์ฟเวอร์" />
</รายการเทมเพลต>
<แก้ไขรายการเทมเพลต>
<ASP:CHECKBOX id = "chkExportON" runat = "เซิร์ฟเวอร์" ที่เปิดใช้งาน = "true" />
</แก้ไขรายการเทมเพลต>
</ASP:TEMPLATECOLUMN>
รหัสแบ็กเอนด์ที่ได้รับ
การป้องกันเป็นโมฆะ CheckAll_CheckedChanged (ผู้ส่งวัตถุ System.EventArgs e)
-
//เปลี่ยนการเลือกคอลัมน์เพื่อเลือกทั้งหมดหรือไม่มีเลย
ช่องทำเครื่องหมาย chkExport;
ถ้า (ตรวจสอบทั้งหมดตรวจสอบแล้ว)
-
foreach (DataGridItem oDataGridItem ใน MyDataGrid.Items)
-
chkExport = (ช่องทำเครื่องหมาย) oDataGridItem.FindControl("chkExport");
chkExport.Checked = จริง;
-
-
อื่น
-
foreach (DataGridItem oDataGridItem ใน MyDataGrid.Items)
-
chkExport = (ช่องทำเครื่องหมาย) oDataGridItem.FindControl("chkExport");
chkExport.Checked = เท็จ;
-
-
}
17. การจัดรูปแบบตัวเลข [ผลลัพธ์ของ <%#Container.DataItem("price")%> คือ 500.0000 จะจัดรูปแบบเป็น 500.00 ได้อย่างไร]
<%#Container.DataItem("price","{0:¥# , ##0.00}")%>
int i=123456;
string s=i.ToString("###,###.00");
18. การจัดรูปแบบวันที่
[ในหน้า aspx: <%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date")%>
แสดงเป็น: 11-8-2547 19:44:28
ฉันแค่ต้องการ: 11-8-2547]
<%# DataBinder.Eval(Container.DataItem, "Company_Ureg_Date", "{0:yyyy-Md}")%>
ฉันจะเปลี่ยนมันได้อย่างไร?
[จัดรูปแบบวันที่]
เอามันออกไป มักจะคัดค้าน
((DateTime)objectFromDB).ToString("yyyy-MM-dd");
[นิพจน์การตรวจสอบสำหรับวันที่]
A. รูปแบบอินพุตที่ถูกต้องต่อไปนี้: [2004-2-29], [2004-02-29 22: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. วิธีการตั้งค่าตัวแปรโกลบอล
ในเหตุการณ์ Application_Start()
ใน Global.asax
ให้เพิ่ม Application[attribute name] = xxx;
ซึ่งเป็นตัวแปรโกลบอลของคุณ
20. จะคลิกการเชื่อมต่อเพื่อเปิดหน้าต่างใหม่หลังจากการเชื่อมต่อที่สร้างโดย HyperLinkColumn ได้อย่างไร
HyperLinkColumn มีแอตทริบิวต์ Target เพียงตั้งค่าเป็น "_blank" (Target="_blank")
[ASPNETMENU] คลิกที่รายการเมนูเพื่อเปิดหน้าต่างใหม่ เพิ่ม URLTarget="_blank" ไปยังรายการเมนูใน menuData ของคุณ ไฟล์ .xml
ชอบ:
<?xml version="1.0" encoding="GB2312"?>
<MenuData ImagesBaseURL="images/">
<กลุ่มเมนู>
<MenuItem Label="ข้อมูลพารามิเตอร์ภายใน" URL="Infomation.aspx" >
<MenuGroup ID="บีบีซี">
<MenuItem Label="ข้อมูลการประกาศ" URL="Infomation.aspx" URLTarget="_blank" LeftIcon="file.gif"/>
<MenuItem Label="เตรียมการบรรยายสรุปข้อมูล" URL="NewInfo.aspx" LeftIcon="file.gif" />
-
วิธีที่ดีที่สุดคืออัปเกรด aspnetmenu ของคุณเป็นเวอร์ชัน 1.2
21 มอบหมายการอภิปราย
http://community.csdn.net/Expert/topic/2651/2651579.xml?temp=.7183191
http://dev.csdn.net/develop/article/22/22951.shtm
22. อ่านค่ากล่องข้อความควบคุม DataGrid
foreach (DataGrid dgi ใน yourDataGrid.Items)
-
กล่องข้อความ tb = (กล่องข้อความ)dgi.FindControl("yourTextBoxId");
tb.ข้อความ....
}
23. มีคอลัมน์เทมเพลตสามคอลัมน์ใน DataGrid ที่มีกล่องข้อความ: DG_ShuLiang (ปริมาณ), DG_DanJian (ราคาต่อหน่วย) และ DG_JinE (จำนวน) ตามลำดับในคอลัมน์ 5.6.7 จำเป็นต้องคำนวณจำนวนเงินโดยอัตโนมัติเมื่อป้อนปริมาณ และราคาต่อหน่วยนั่นคือ: ปริมาณ * ราคาต่อหน่วย = จำนวนเงินจะต้องถูกจำกัดไว้ที่ค่าตัวเลขเมื่อป้อน ฉันจะใช้สคริปต์ไคลเอนต์เพื่อใช้ฟังก์ชันนี้ได้อย่างไร
〖Sigui〗
<asp:TemplateColumn HeaderText="ปริมาณ">
<เทมเพลตรายการ>
<asp:TextBox id="ShuLiang" runat='server' Text='<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>'
onkeyup="javascript:DoCal()"
/ >
<asp:RegularExpressionValidator id = "revS" runat = "เซิร์ฟเวอร์" ControlToValidate = "ShuLiang" ErrorMessage = "ต้องเป็นจำนวนเต็ม" ValidationExpression = "^d+$" />
</เทมเพลตรายการ>
</asp:TemplateColumn>
<asp:TemplateColumn HeaderText="ราคาต่อหน่วย">
<เทมเพลตรายการ>
<asp:TextBox id="DanJian" runat='server' Text='<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>'
onkeyup="javascript:DoCal()"
/ >
<asp:RegularExpressionValidator id = "revS2" runat = "เซิร์ฟเวอร์" ControlToValidate = "DanJian" ErrorMessage = "ต้องเป็นตัวเลข" ValidationExpression = "^d+(.d*)?$" />
</ItemTemplate>
</asp:TemplateColumn>
<asp:TemplateColumn HeaderText="จำนวน">
<เทมเพลตรายการ>
<asp:TextBox id="JinE" runat='server' Text='<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>' />
</เทมเพลตรายการ>
</asp:TemplateColumn>
<ภาษาสคริปต์ = "จาวาสคริปต์">
ฟังก์ชั่นDoCal()
-
var e = event.srcElement;
แถว var = e.parentNode.parentNode;
var txts = row.all.tags("อินพุต");
ถ้า (!txts.length || txts.length < 3)
กลับ;
var q = txts[txts.length-3].value;
var p = txts[txts.length-2].value;
ถ้า (คือNaN(q) || isNaN(p))
กลับ;
q = parseInt(q);
p = parseFloat(p);
txts[txts.length-1].value = (q * p).toFixed(2);
-
</สคริปต์>
24.เมื่อเลือกแถวด้านล่างของ DataGrid เพื่อเปรียบเทียบ เหตุใดจึงรีเฟรชแล้วเลื่อนไปด้านบนเสมอ แถวที่เพิ่งเลือกไม่สามารถมองเห็นได้เนื่องจากหน้าจอ
page_load
page.smartNavigation=true
25. แก้ไขข้อมูลใน Datagrid เมื่อคลิกคีย์แก้ไข ข้อมูลจะปรากฏในกล่องข้อความ จะควบคุมขนาดของกล่องข้อความได้อย่างไร
?
-
สำหรับ (int i=0;i<e.Item.Cells.Count-1;i++)
ถ้า(e.Item.ItemType==ListItemType.EditType)
-
e.Item.Cells.Attributes.Add("ความกว้าง", "80px")
}
-
26. กล่องโต้ตอบ
สตริงคงที่ส่วนตัว ScriptBegin = "<script language="JavaScript">";
สตริงคงที่ส่วนตัว ScriptEnd = "</script>";
โมฆะสาธารณะคงที่ ConfirmMessageBox (สตริง PageTarget เนื้อหาสตริง)
{
string ConfirmContent="var retvalue="/blog/window.confirm('"+Content+"');"+"if(retValue){window.location="'"+PageTarget+"';}";
ConfirmContent=ScriptBegin + ยืนยันเนื้อหา + ScriptEnd;
Page parameterPage = (เพจ) System.Web.HttpContext.Current.Handler;
ParameterPage.RegisterStartupScript("ยืนยัน",ยืนยันเนื้อหา);
//Response.Write(strScript);
}
http://www.cnblogs.com/robber/archive/2007/01/09/615835.html