WebForm框架页面上js修改服务端控件导致后台不能正确获取到控件值的问题【总结】

16 篇文章 0 订阅
10 篇文章 0 订阅

WebForm框架页面上js修改服务端控件导致后台不能正确获取到控件值的问题

页面代码

                <td><span id="sp_notice_type_item">公告类型</span></td>
                <td style="width:110px;">
                    <asp:DropDownList ID="ddl_notice_type_item</span>" runat="server">
                        <asp:ListItem Value="-1">-选择-</asp:ListItem>
                        <asp:ListItem Value="1">运维公告</asp:ListItem>
                        <asp:ListItem Value="2">产品公告</asp:ListItem>
                        <asp:ListItem Value="3">活动公告</asp:ListItem>
                    </asp:DropDownList>
                </td>

js业务逻辑控制

         if (type == "0")
         {
             $("#sp_notice_type_item").html("公告类型");
             $("#ddl_notice_type_item").html("<option value='-1'>-选择-</option><option value='1'>运维公告</option><option value='2'>产品公告</option><option value='4'>活动公告</option>");
         }
         if (type == "1")
         {
             $("#sp_notice_type_item").html("问题类型");
             $("#ddl_notice_type_item").html("<option value='-1'>-选择-</option><option value='1'>热门问题</option><option value='2'>新手须知</option><option value='3'>隐私说明</option>");
         }

后台代码

ddl_notice_type_item.SelectedValue //此用法在提交时报错如下,刷新后正常提交,但是下拉选项有变动时获取到的值为-1,即未取到实际的值

回发或回调参数无效。在配置中使用 <pages enableEventValidation="true"/> 或在页面中使用 <%@ Page EnableEventValidation="true" %> 启用了事件验证。出于安全目的,此功能验证回发或回调事件的参数是否来源于最初呈现这些事件的服务器控件。如果数据有效并且是预期的,则使用 ClientScriptManager.RegisterForEventValidation 方法来注册回发或回调数据以进行验证。



解决办法:

在页面page属性中加上EnableEventValidation="false"

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Add.aspx.cs" Inherits="WebApplication1.MainAdmin.News.Add" EnableEventValidation="false" %>

后台获取控件值使用

Request.Form["ddl_notice_type_item"] //可以正常获取下拉选项的值



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据的流

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值