 |
|
มาลองใช้ codebehide สร้าง page ของ asp.net กัน asp.net เป็น oop controls ต่างๆ เป็น object หมด |
|
 |
|
|
 |
 |
|
asp.net เป็น oop controls ต่างๆ เป็น object หมด ดังนั้นเราจึงสามารถอ้างอิง
หรือสร้างขึ้นมาใช้งานจาก server script ได้ ไม่เว้นแม้กระทั้ง tag html ต่างๆ ด้วย
Default.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
</div>
</form>
</body>
</html>
จริงๆ สามรถลบ tag html head body ทิ้งทั้งหมดแล้วสร้างใน code behide ก็ได้แต่ไหนๆ
มัน gen ให้อยู่แล้วก็ปล่อยเลยตามเลยแล้วกัน 
Default.aspx.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Net;
using System.Text;
using System.Web.UI.HtmlControls;
public partial class _Default : System.Web.UI.Page
{
private const int MaxEmoticon = 30;
protected void Page_Load(object sender, EventArgs e)
{
CreateHeaderElement();
CreateJavaScript();
CreateBodyElement();
}
protected void CreateHeaderElement()
{
Page.Title = "ThaiCreate Old Emoticon";
Page.Header.Controls.Add(new LiteralControl(Environment.NewLine));
HtmlMeta charSet = new HtmlMeta();
charSet.HttpEquiv = "Content-Type";
charSet.Content = "text/html; charset=utf-8";
Page.Header.Controls.Add(charSet);
Page.Header.Controls.Add(new LiteralControl(Environment.NewLine));
HtmlLink cssStyle = new HtmlLink();
cssStyle.Attributes.Add("type", "text/css");
cssStyle.Attributes.Add("rel", "stylesheet");
cssStyle.Href = "https://www.thaicreate.com/style/Style.css";
Page.Header.Controls.Add(cssStyle);
Page.Header.Controls.Add(new LiteralControl(Environment.NewLine));
HtmlGenericControl script = new HtmlGenericControl();
script.TagName = "script";
script.Attributes.Add("type", "text/javascript");
script.Attributes.Add("src", "jsfile.js");
Page.Header.Controls.Add(script);
Page.Header.Controls.Add(new LiteralControl(Environment.NewLine));
}
protected void CreateBodyElement()
{
Table Table1 = new Table();
Table1.BorderStyle = BorderStyle.Solid;
Table1.BorderWidth = 1;
Table1.BorderColor = System.Drawing.Color.Black;
Table1.GridLines = GridLines.Both;
Table1.CellPadding = 2;
Table1.CellSpacing = 0;
Page.Form.Controls.Add(Table1);
TableHeaderRow HeaderRow = new TableHeaderRow();
Table1.Rows.Add(HeaderRow);
TableHeaderCell HeaderCell1 = new TableHeaderCell();
HeaderCell1.Text = "ID";
HeaderCell1.HorizontalAlign = HorizontalAlign.Center;
HeaderRow.Cells.Add(HeaderCell1);
TableHeaderCell HeaderCell2 = new TableHeaderCell();
HeaderCell2.Text = "Pic";
HeaderCell2.HorizontalAlign = HorizontalAlign.Center;
HeaderRow.Cells.Add(HeaderCell2);
TableHeaderCell HeaderCell3 = new TableHeaderCell();
HeaderCell3.Text = "Image URL";
HeaderCell3.HorizontalAlign = HorizontalAlign.Center;
HeaderRow.Cells.Add(HeaderCell3);
TableHeaderCell HeaderCell4 = new TableHeaderCell();
HeaderCell4.Text = "Button";
HeaderCell4.HorizontalAlign = HorizontalAlign.Center;
HeaderRow.Cells.Add(HeaderCell4);
for (int i = 0; i < MaxEmoticon; i++)
{
TableRow tableRow = new TableRow();
Table1.Rows.Add(tableRow);
TableCell TableCell1 = new TableCell();
TableCell1.HorizontalAlign = HorizontalAlign.Center;
tableRow.Cells.Add(TableCell1);
TableCell TableCell2 = new TableCell();
TableCell2.HorizontalAlign = HorizontalAlign.Center;
tableRow.Cells.Add(TableCell2);
TableCell TableCell3 = new TableCell();
tableRow.Cells.Add(TableCell3);
TableCell TableCell4 = new TableCell();
TableCell4.HorizontalAlign = HorizontalAlign.Center;
tableRow.Cells.Add(TableCell4);
Label Label1 = new Label();
Label1.Text = Convert.ToString(i + 1);
TableCell1.Controls.Add(Label1);
Image Image1 = new Image();
TableCell2.Controls.Add(Image1);
TextBox TextBox1 = new TextBox();
TextBox1.ReadOnly = true;
TextBox1.Text = "https://www.thaicreate.com/images/old_resource/" + ImageFile(i + 1) + ".gif";
TextBox1.Width = 350;
TableCell3.Controls.Add(TextBox1);
Button Button1 = new Button();
Button1.Text = "Select";
Button1.Attributes.Add("onclick", "javascript:SelectText('" + TextBox1.ClientID + "'); return false;");
TableCell4.Controls.Add(Button1);
if (FileExist("https://www.thaicreate.com/images/old_resource/" + ImageFile(i + 1) + ".gif"))
{
Image1.ImageUrl = "https://www.thaicreate.com/images/old_resource/" + ImageFile(i + 1) + ".gif";
}
else
{
Image1.ImageUrl = "http://forums.regonline.com/forums/images/DeleteIcon.gif";
TableCell4.Controls.Remove(Button1);
TableCell4.Text = " ";
}
}
}
protected void CreateJavaScript()
{
StringBuilder stringBuilder = new StringBuilder();
stringBuilder.Append("function SelectText(txtBoxName)\n");
stringBuilder.Append("{\n");
stringBuilder.Append("\tvar txtBox = document.getElementById(txtBoxName);\n\n");
stringBuilder.Append("\ttxtBox.focus();\n");
stringBuilder.Append("\ttxtBox.select();\n");
stringBuilder.Append("}\n");
ClientScriptManager ClientScript = Page.ClientScript;
if (!ClientScript.IsClientScriptBlockRegistered(this.GetType(), "SelectText"))
ClientScript.RegisterClientScriptBlock(this.GetType(), "SelectText", stringBuilder.ToString(), true);
}
protected string ImageFile(int Index)
{
string txt = string.Empty;
txt = Index.ToString().Length == 1 ? txt = "o0" + Index.ToString() : "o" + Index.ToString();
return txt;
}
protected bool FileExist(string url)
{
HttpWebRequest request = null;
HttpWebResponse response = null;
bool exist = false;
try
{
request = (HttpWebRequest)WebRequest.Create(url);
request.KeepAlive = true;
response = (HttpWebResponse)request.GetResponse();
exist = true;
}
catch (WebException)
{
}
finally
{
if (response != null)
response.Close();
}
return exist;
}
}
เขียนเสร็จลองรัน แล้ว view source ดู
Tag : - - - -
|
|
 |
 |
 |
 |
Date :
2010-03-29 15:13:23 |
By :
tungman |
View :
2445 |
Reply :
12 |
|
 |
 |
 |
 |
|
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
จะบวกให้กำลังก็ไม่ได้ ดันเป็น Guest 
|
 |
 |
 |
 |
Date :
2010-03-29 18:19:33 |
By :
plakrim |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
เขียน .NET ยิ่งเขียนยิ่งสนุกครับ เพราะมีอะไรมากมายให้เราศึกษา
|
 |
 |
 |
 |
Date :
2010-03-29 18:31:02 |
By :
webmaster |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
เทพค่ะพี่ตึ๋งศรีอย่างนี้เทพแล้ว ^ ^
|
 |
 |
 |
 |
Date :
2010-03-29 20:50:10 |
By :
blurEye |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
ภาษาวัยรุ่น เขาเรียก เมพขิงๆ ใช่ไหมครับ 
|
 |
 |
 |
 |
Date :
2010-03-29 22:20:23 |
By :
plakrim |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
อิอิ บ้ายอเหมือนกันวุ้ยเรานี่ แต่ .net มันยังมีอะไรให้เรียนรู้อีกเยอะเลย ตอนนี้ก็กำลังดู silverlight อยู่
เอาที่เหลือมารวมไว้เผื่อใครเอาไปใช้
แบบไม่มีอะไรเลย มีแบบบอกว่าใช้ code behide ไหน
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="html.aspx.cs" Inherits="html" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
สร้าง html tag, head tag และ body กับ form
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
public partial class html : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
HtmlGenericControl html = new HtmlGenericControl();
html.TagName = "html";
html.Attributes.Add("xmlns", "http://www.w3.org/1999/xhtml");
Page.Controls.Add(html);
HtmlHead header = new HtmlHead();
html.Controls.Add(header);
HtmlGenericControl body = new HtmlGenericControl();
body.TagName = "body";
html.Controls.Add(body);
HtmlForm form1 = new HtmlForm();
form1.ID = "form1";
form1.EnableViewState = true;
body.Controls.Add(form1);
}
}
|
 |
 |
 |
 |
Date :
2010-03-29 22:59:42 |
By :
tungman |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
Code (C#)
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
</div>
</form>
</body>
</html>
จากเจ้านี้เราสามารถอ้างอิง tag ต่างๆ ของ html ได้เช่น head กับ form ด้วย property ของ class page
เช่น ต้องการ add control ลง head ก็ใช้
Code (C#)
Page.Header.Controls.Add(control);
ต้องการ add control ลง form ก็ใช้
Code (C#)
Page.Form.Controls.Add(control);
A: แต่สมมติว่าถ้าเราอยากจะ add control หรือเพิ่ม attibute ลงใน tag body ล่ะจะอ้างอิงอย่างไร ?
Q: ต้องใช้ class HtmlControls
Code (C#)
HtmlControl body = (HtmlControl)Page.FindControl("Body");
body.Attributes.Add("onload", "alert('hello world');");
ซึ่งสามารถใช้ได้กับทุกๆ tag html เลย สามารถเอา tag ที่ต้องการจับมาเป็น object ใช้ในการอ้างอิงได้เลย
|
 |
 |
 |
 |
Date :
2010-03-30 08:26:21 |
By :
tungman |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
การเขียนใน codebehide มันมักจะยาวกว่าเขียนใน design ซึ่งถ้าลำบากนักก็เขียนที่ design
อย่างเดิมเถอะ แต่ถ้าจำเป็นต้องเขียนแบบ dynamic
asp.net ก็สามารถใช้ความสามารถของ oop สร้างหรืออ้างอิง control ทั้งหลายใน page ได้เช่นกัน
|
 |
 |
 |
 |
Date :
2010-03-30 08:32:23 |
By :
tungman |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
+1 จัดไป ขอบคุณครับ ปกติผมก็เขียนแบบ codebehide เพราะผมไม่ได้มาทางสาย html มาทางสาย .net เลย พวกแท็ค html ไม่ค่อยมั่นใจ
|
 |
 |
 |
 |
Date :
2010-03-30 08:39:50 |
By :
numenoy |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
ยอดเลยครับพี่ มีทักษะอะไรดีๆ เอามาลงสอนน้องๆ อีกนะครับ
silverlight นิก็ได้นะครับมาลงบทความสอนหน่อย อิอิๆ ชอบ ๆ Microsoft
|
 |
 |
 |
 |
Date :
2010-03-31 02:42:04 |
By :
chakrit021 |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
ผมก็ไม่ได้คลั่ง ms มากมักหรอกครับ แต่อะไรที่มันดีก็อยากศึกษา
เจ้า silverlight เนี่ยผมไม่ได้มองเรื่องการใช้งาน multimadia เลย แต่มองเกี่ยวกับ
การสร้าง user interface ของ app บนเว็บ คือมันเป็นโปรแกรมจริงๆ
แต่รันบนเว็บได้ ซึ่งแต่ต่างจาก flash ที่เป็นแค่ action script ก็เลยลองเล่นดู
ตอนนี้ยังไม่พร้อมจะแนะครับ ยังต้องศึกษาอีกน้อย
|
 |
 |
 |
 |
Date :
2010-03-31 11:15:00 |
By :
tungman |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
 |
|
|
 |
 |
|
กำลังรอสูบความรู้จากคุณ tungman อยู่ครับ อิอิอิ
|
 |
 |
 |
 |
Date :
2010-03-31 19:14:54 |
By :
kenessar |
|
 |
 |
 |
 |
|
|
 |
 |
|
 |
 |
|
|