通过jquery(asp.net gridview、radcombobox)在dom中查找并切换div

通过jquery(asp.net gridview、radcombobox)在dom中查找并切换div,jquery,asp.net,gridview,telerik,next,Jquery,Asp.net,Gridview,Telerik,Next,我在asp.net gridview中使用radcombobox。 现在,如果用户从组合框中选择一个特殊的值,我想设置一个divs可见性。但是由于渲染的代码,我不知道我必须做什么 这是呈现的代码: <td> <div class="colColor DivInHere" style="margin-top:8px;margin-right:2px;display:inline-block;float:left;">Artikel</div> &

我在asp.net gridview中使用radcombobox。 现在,如果用户从组合框中选择一个特殊的值,我想设置一个divs可见性。但是由于渲染的代码,我不知道我必须做什么

这是呈现的代码:

<td>
    <div class="colColor DivInHere" style="margin-top:8px;margin-right:2px;display:inline-block;float:left;">Artikel</div>
    <div class="colColor" style="margin-top:7px;float:left;margin-left:28px;">
        <div id="ctl00_ContentPlaceHolder1_gvRechnungsposition_ctl02_rcbArtikel" class="RadComboBox RadComboBox_Metro" style="width:200px;margin-left:5px;">
            <table class="rcbFocused" style="border-width: 0px; border-collapse: collapse;" summary="combobox">
                <tbody>
                    <tr>
                        <td class="rcbInputCell rcbInputCellLeft" style="width:100%;">
                            <input id="ctl00_ContentPlaceHolder1_gvRechnungsposition_ctl02_rcbArtikel_Input" class="rcbInput radPreventDecorate" type="text" style="color:rgb(166, 204, 213);" value="Bitte wählen ..." name="ctl00$ContentPlaceHolder1$gvRechnungsposition$ctl02$rcbArtikel" autocomplete="off">
                        </td>
                        <td class="rcbArrowCell rcbArrowCellRight">
                            <a id="ctl00_ContentPlaceHolder1_gvRechnungsposition_ctl02_rcbArtikel_Arrow" style="overflow: hidden;display: block;position: relative;outline: none;">select</a>
                        </td>                   
                    </tr>
                </tbody>
            </table>
            <input id="ctl00_ContentPlaceHolder1_gvRechnungsposition_ctl02_rcbArtikel_ClientState" type="hidden" name="ctl00_ContentPlaceHolder1_gvRechnungsposition_ctl02_rcbArtikel_ClientState" autocomplete="off" value="{"logEntries":[],"value":"Benutzerdefiniert","text":"Benutzerdefiniert","enabled":true,"checkedIndices":[],"checkedItemsTextOverflows":false}">
        </div>
    </div>
    <div style="clear:both"></div>
</td>
<td>
    <div class="colColor in" style="margin-left:10px;margin-right:10px;display:none;">
</td>

我希望你明白我想做什么,感谢你阅读

好的,我找到了一个适合我的解决方案。 也许它能帮助有类似问题的人:

主要的问题是,我忘了从我的radcombobox中获取正确的ID。 我是这样做的:var currentId=+$sender.attr''u clientStateFieldID';

这就是我的职责:

            function OnClientSelectedIndexChanged(sender, eventArgs) {
            var item = eventArgs.get_item();

            var selItem = item.get_text();
            if (selItem == "Benutzerdefiniert") {
                //$(".in").toggle();
                $(this).closest('td > tr > tbody > table > div > div > td').next('td').find('.in').show();
            };

        }
function OnClientSelectedIndexChanged(sender, eventArgs) {

            var item = eventArgs.get_item();
            var selItem = item.get_text();
            var currentId = '#' + $(sender).attr('_clientStateFieldID');

            if (selItem == "Benutzerdefiniert") {
                $(currentId).parent().parent().parent().next('td').find('div.in').toggle();
            } else {
                $(currentId).parent().parent().parent().next('td').find('div.in').hide();
            };

        }
同样,肯定有更好的解决方案

function OnClientSelectedIndexChanged(sender, eventArgs) {

            var item = eventArgs.get_item();
            var selItem = item.get_text();
            var currentId = '#' + $(sender).attr('_clientStateFieldID');

            if (selItem == "Benutzerdefiniert") {
                $(currentId).parent().parent().parent().next('td').find('div.in').toggle();
            } else {
                $(currentId).parent().parent().parent().next('td').find('div.in').hide();
            };

        }