javascript - jQuery 追加/添加隐藏 div 到 jQuery 对话框

标签 javascript jquery html css jquery-dialog

我正在尝试将 HTML 文件中的 div 元素附加/添加到对话框(当前有一些按钮)。 div 在页面加载时通过 CSS 类“hide”隐藏

HTML DIV:

<section>
            <div id="deliveryMethod" title="Delivery Method" class="hide">
                <p>Please select delivery method and special requirements.</p>                    
                <ul>
                    <li>
                        <label>Method:</label>
                    </li>
                    <li>
                        <div>
                            <select for="deliveryService">
                                <option value="">Please select...</option>
                                <option value="FedEx">FedEx</option>
                                <option value="UPS">UPS</option>
                            </select>
                        </div>
                    </li>
                    <li>
                        <label>Special Requirements:</label>                            
                    </li>
                    <li>
                        <textarea id="specialRequirements" type="text" value=""  maxlength="220"></textarea>
                    </li>
                </ul>
            </div>
    </section>

CSS 类=隐藏

.hide {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

单击按钮时的 jQuery,我调用以下函数:

function deliveryServiceClick() {

$("#dialogDiv").dialog("open");

if ($('#dialogDiv').length == 0) {
    $('body').append("<div id='dialogDiv'><div/>");
}
var dialogDiv = $('#dialogDiv');

dialogDiv.attr("Title", "Please select your chosen delivery service.");
dialogDiv.html("<div id='deliveryMethod'><div/>");
$('body').append("<div id='deliveryMethod'><div/>");

dialogDiv.dialog({
    modal : true,
    buttons : [
            {
                text : "Process",
                class : 'large',
                click : function() {
                    //              
                }
            },
            {
                text : "Cancel",
                class : 'large',
                click : function() {
                    $(this).dialog('close');
                }
            } ]
});
}

如您所见,我尝试使用以下方法附加/显示我的隐藏 div:

dialogDiv.html("<div id='deliveryMethod'><div/>");
$('body').append("<div id='deliveryMethod'><div/>");

在我的 jQuery 中定义的按钮将出现在 div 下方。

如有任何帮助,我们将不胜感激。

谢谢

最佳答案

尝试

function deliveryServiceClick() {
    var dialogDiv = $('#dialogDiv');

    $("#dialogDiv").dialog("open");

    if (dialogDiv.length == 0) {
        dialogDiv = $("<div id='dialogDiv'><div/>").appendTo('body');
        $('#deliveryMethod').appendTo(dialogDiv).removeClass('hide')
        dialogDiv.attr("Title", "Please select your chosen delivery service.");

        dialogDiv.dialog({
            modal : true,
            buttons : [
                {
                    text : "Process",
                    class : 'large',
                    click : function() {
                        //              
                    }
                },
                {
                    text : "Cancel",
                    class : 'large',
                    click : function() {
                        $(this).dialog('close');
                    }
                } ]
        });
    }else{
        dialogDiv.dialog("open");
    }
}

演示:Fiddle

关于javascript - jQuery 追加/添加隐藏 div 到 jQuery 对话框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16479398/

相关文章:

jquery - 在日期选择器中合并月份

javascript - 将 PHP 脚本返回的数据传递到 Highcharts data[] block 中?

javascript - JQuery - 写入开启器窗口

c# - 如何在不调用 Controller 的情况下刷新 MVC webgrid

javascript - Angular 2/4/5(不是 AngularJS):- how can I take . offset().top 元素?

javascript - 使用 javascript 隐藏/显示 div

javascript - 下拉值在 nog 选项 Angular 中复制

javascript - 多个用户打开的具有相同 url 的窗口之间的通信

javascript - Node.js 无法识别 Coffeescript

javascript - 异步给出回调已经调用错误?