加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – gridview中的标签更改但更改不回发

发布时间:2020-12-15 21:47:13 所属栏目:百科 来源:网络整理
导读:我有一个带有标签的gridview,以及一些 JavaScript和jQuery来使标签可编辑. 但是,当我在我的代码后面回发和调试时,我看不到变化. 我怎样才能做到这一点我可以在服务器上进行更改? asp:GridView ID="gvGroups" runat="server" AutoGenerateColumns="False" Cs
我有一个带有标签的gridview,以及一些 JavaScript和jQuery来使标签可编辑.

但是,当我在我的代码后面回发和调试时,我看不到变化.

我怎样才能做到这一点我可以在服务器上进行更改?

<asp:GridView ID="gvGroups" runat="server" AutoGenerateColumns="False"
 CssClass="table table-hover table-striped" GridLines="None" >
    <Columns>
        <asp:TemplateField HeaderText="Name" SortExpression="GroupDescription">
            <ItemTemplate>
                <asp:Label ID="lblName" CssClass="edit" runat="server" Text='<%# Eval("GroupDescription") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>

function makeLabelsEditable() {

    $(".edit").focusout(function () {
        setLabel(this);
    });

    $(".edit").click(function () {
        editLabel(this);
    });
}

function editLabel(source) {
    source.innerHTML = '<input type="text" maxlength="40" value="' + source.innerHTML + '"/>';
    $(source).unbind('click');
    source.children[0].focus()
}
function setLabel(source) {    
    if (source.children[0].value != '') {
        $(source).click(function () {
            editLabel(this);
        });
        source.innerHTML = source.children[0].value;
    }    
}

解决方法

Label不会回发到服务器.它们旨在只读并呈现为跨度.如果你想要它回发最简单的事情是使用相同的值创建一个隐藏控件,当你编写代码以允许编辑标签时,你一定要将编辑后的值写入隐藏.隐藏将被发回服务器,然后您可以读取值.

您正在交换“动态”TextBox,因此服务器不知道您所做的输入控件.您可以阅读原始发布的参数以获取该值,但是您可以更容易地创建一个可以写入的静态控件并知道它将具有您需要的值.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读