Analytics

2010年6月8日 星期二

[Javascript]Button控制項與Javascript配合Client Button控制項變更Textbox的值(Button controls and Javascript with Client Button controls to change the value Textbox)


問題
Button控制項與Javascript配合Client Button控制項變更Textbox的值



解決方法
使用Server端的控制項,處理方式是將Client的整個網頁傳回Server,然後在Server端變更Textbox的值以後,再回傳整個網頁回來Client端
使用Javascript配合html的input button,處理方式是直接由Javascript取得要變更的控制項id後,直接給值
而前後者不同的是一個再Server端執行,一個則由Client處理完成,若網頁上的控制項很多,使用Server端的方式執行將會造成網路流量的增加,使用上須小心!
.aspx如下:
<%@ Page Language="C#" AutoEventWireup="true" Codebehind="Default.aspx.cs" Inherits="WebApplication1._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>
<script language="javascript">
    function cilckbtn(btnID)
    {
        var myText=null
        //取得並觸發按鍵動作
        myText="Javascript call me"
        document.getElementById(btnID).value=myText;
    }
</script>
<body>
    <form id="form1" runat="server">
        <div>
            <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
            <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
           <%--按下btnServerCall的時候去Postback候傳回變更後的Textbox值--%>
            <asp:Button ID="btnServerCall" runat="server" OnClick="Button1_Click" Text="ServerCall" />
           <%--按下btnJavaScriptCall的時候去觸發javascript--%>
            <input id="btnJavaScriptCall" type="button" value="JavaScriptCall" onclick="cilckbtn('TextBox1');"/></div>
    </form>
</body>
</html>
.cs如下:
namespace WebApplication1
{
    public partial class _Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
        }
        protected void Button1_Click(object sender, EventArgs e)
        {
            this.TextBox1.Text = "Service call me";
        }
    }
}

沒有留言:

熱門文章