如何根据点击在jqueryui上填充占位符



我在jqueryui上根据单击加载占位符时遇到问题。我已经从后台填充了。我需要根据accordin标题点击来填充占位符。

这是我的html

<html>
<head>
    <script>
    $(function () {
        $('#login').button({ icons: { primary: "ui-icon-person"} });
        $('#showDataSource').button({ icons: { primary: "ui-icon-newwin"} });
        $('#logout').button({ icons: { primary: "ui-icon-locked"} });
        $('#login').click(function () {
            var panel = $('#loginPanel').dialog({ modal: true });
            panel.parent().appendTo($("form:first"));
        });
        $('#logout').click(function () {
            (function (event) {
            });
        });
        $('#showDataSource').click(function () {
            $('#dataSource').dialog({ modal: true, width: 1000, height: 700 });
            $('.accordion').accordion({ autoHeight: false, navigation: true, collapsible: true,
                active: false,
                changestart: function (event, ui) {
                    var dataSourceID = ui.newHeader.find('a').attr('id');
                    //var dataSourceColumn = EasyOutputWeb.Services.GetDataSourceColumns(dataSourceID, onsuccess, onError);
                    $.post(dataSourceID, function (data) {
                        //ui.newHeader.next("div").html(dataSourceID);
                        $('#columnPlaceHolder').html(dataSourceID);
                    });
                }
            });
        });
    });
    function onsuccess(msg) {
        alert(msg);
    }
    function onError(msg) {
        alert(msg);
    }
    </script>
</head>
<body>
        <div id="dataSource" runat="server">  
                <div class="divtable">  
                    <div class="headrow" id="#accordianHeight">  
                        <div class="divcol">  
                            Data Sources</div>  
                        <div class="divcol" >  
                            Columns</div>  
                        <div class="divcol">  
                            Strong Keys</div>  
                    </div>  
                    <div class="divrow">  
                        <div class="content">  
                            <div class="accordion" id="accordianHeight">  
                                <asp:PlaceHolder ID="dataPlaceHolder" runat="server" />  
                            </div>  
                        </div>  
                        <div class="content">  
                            <div id="dataColumn">  
                                test column  
                                <asp:PlaceHolder ID="columnPlaceHolder" runat="server" />  
                            </div>  
                        </div>  
                        <div class="content" >  
                            <div id="dataKey">  
                                Test key  
                                <asp:PlaceHolder ID="keyPlaceHolder" runat="server" />  
                            </div>  
                        </div>  
                    </div>  
                </div>  
            </div>  
</body>
</html>

这里的第一个错误是使用PlaceHolder,因为它们没有被任何标记扭曲,所以jQuery无法获取它们。使用Panel,随着内容的span或div而扭曲。

第二个错误是,当asp.net渲染它们时,每个的最终id都是从.ClientID属性中获得的,因此jQuery的代码将为:

$('#<%=columnPlaceHolder.ClientID%>').html(dataSourceID);

还有一条注释,如果你实际上没有在Panel的代码后面添加任何控件,那么你只需放置一个<div id="columnPlaceHolder"></div>代码就可以在上面编写,并像现在一样使用jQuery调用(不要添加CliendID)

最新更新