textBox ontextChanged在用户添加文本时不触发

时间:2012-03-13 15:51:45

标签: c# asp.net forms textbox

我在这样的转发器中创建一个textBox(因此在循环中创建了许多文本框并添加到转发器控件中)

.aspx.cs

 TextBox textBox = new TextBox();
 textBox.TextChanged += new EventHandler(textBox_TextChanged);

我有一个这样的函数,用于将textBox背景颜色更改为白色,如果该文本框有一些文本(在创建表单时为黄色)

protected void textBox_TextChanged(object sender, EventArgs e)
{
    TextBox textBox = sender as TextBox;
    if (textBox.Text != String.Empty)
    {
        textBox.BackColor = System.Drawing.Color.White;
    }
}

但功能似乎根本没有被击中。关于我做错了什么的指示?

感谢。

3 个答案:

答案 0 :(得分:4)

我建议将往返保存到服务器并使用javascript进行。在后面的代码中创建控件时,添加 onchange 客户端事件属性并处理它:

myTextBox.Attributes.Add("onchange", 
       "this.style.backgroundColor = (this.value != '')?'#fff':'yellow';");

希望它有所帮助!

答案 1 :(得分:0)

示例javaScript

<script type="text/javascript" language="javascript">
    function runScript(evt, ID) {
        var ctl = document.getElementById(ID.id);
        if (ctl.value == '') {
            ctl.style.backgroundColor = '#FFFF00';
        }
        else
            ctl.style.backgroundColor = '#FFFFFF';

        return true;
    }
</script>

示例转发器控件HTML

<asp:Repeater ID="rpt" runat="server">
    <HeaderTemplate>
        <table>
            <tr>
                <td>
                    textBox
                </td>
            </tr>
    </HeaderTemplate>
    <ItemTemplate>
        <tr>
            <td>
                <asp:TextBox ID="ed" runat="server" BackColor="Yellow" onkeyUp="return runScript(event, this)" autocomplete="off"></asp:TextBox>
            </td>
        </tr>
    </ItemTemplate>
    <FooterTemplate>
        </table>
    </FooterTemplate>
</asp:Repeater>

答案 2 :(得分:0)

谢谢你们的帮助。这是我使用的最终代码 .aspx.cs。

textBox.Attributes.Add("onkeypress","javascript:changebackgroundcolor()");

的.aspx

<script type="text/javascript">
        function changebackgroundcolor() {
            var element;
            for (var i = 0; i < document.forms[0].elements.length; i++) {
                element = document.forms[0].elements[i];

                switch (element.type) {
                    case 'textarea':
                        if (element.value.length > 0) {
                            element.style.borderwidth = "thin";
                            element.style.bordercolor = "White";
                            element.style.borderstyle = "solid";
                        }
                        break;
                }
            }
        }
</script>