jQueryUI 扩展对话框

发布于 2025-01-04 14:49:57 字数 7688 浏览 2 评论 0原文

我正在尝试使用下面的代码来扩展 jQueryUI 对话框以达到类似的效果:http://www.schillmania.com/projects/dialog/png/

一切正常,除了当我单击按钮关闭对话框时什么也没发生。

(function( $, undefined ) {

    var uiDialogClasses = "ui-dialog ui-widget ui-widget-content roundbox";

    $.widget("custom.mydialog", $.ui.dialog, {

        _super_create: $.ui.dialog.prototype._create,
        _create: function() {
            this.originalTitle = this.element.attr( "title" );
            // #5742 - .attr() might return a DOMElement
            if ( typeof this.originalTitle !== "string" ) {
                this.originalTitle = "";
            }       
            this.oldPosition = { 
                parent: this.element.parent(), 
                index: this.element.parent().children().index( this.element ) 
            };
            this.options.title = this.options.title || this.originalTitle;
            var self = this,
                options = self.options,

                title = options.title || " ",
                titleId = $.ui.dialog.getTitleId( self.element ),

                uiDialog = ( self.uiDialogOriginal = $( '<div class="lbasDialog">' ) )
                    //.addClass( uiDialogClasses + options.dialogClass)
                    // setting tabIndex makes the div focusable
                    .attr( "tabIndex", -1)
                    .keydown(function( event ) {
                        if ( options.closeOnEscape && !event.isDefaultPrevented() && event.keyCode &&
                                event.keyCode === $.ui.keyCode.ESCAPE ) {
                            self.close( event );
                            event.preventDefault();
                        }
                    })
                    .attr({
                        role: "dialog",
                        "aria-labelledby": titleId
                    })
                    .mousedown(function( event ) {
                        self.moveToTop( false, event );
                    })
                    .appendTo( "body" )
                    .wrap('<div class="dialog"><div class="bd"><div class="c"><div class="s"></div></div></div></div>')

                    self.uiDialog = $('div.dialog');

                     $('div.dialog')
                       .prepend('<div class="hd">'+
                         '<div class="c"></div></div>')
                       .append('<div class="ft">'+
                         '<div class="c"></div></div>')
                       .addClass( uiDialogClasses + options.dialogClass);



                uiDialogContent = self.element
                    .show()
                    .removeAttr( "title" )
                    .addClass( "ui-dialog-content ui-widget-content" )
                    .appendTo( uiDialog ),

                uiDialogTitlebar = ( self.uiDialogTitlebar = $( "<div>" ) )
                    .addClass( "ui-dialog-titlebar  ui-widget-header  " +
                        "ui-corner-all  ui-helper-clearfix" )
                    .prependTo( uiDialog ),

                uiDialogTitlebarClose = $( "<a href='#'></a>" )
                    .addClass( "ui-dialog-titlebar-close  ui-corner-all" )
                    .attr( "role", "button" )
                    .click(function( event ) {
                        event.preventDefault();
                        self.close( event );
                    })
                    .appendTo( uiDialogTitlebar ),

                uiDialogTitlebarCloseText = ( self.uiDialogTitlebarCloseText = $( "<span>" ) )
                    .addClass( "ui-icon ui-icon-closethick" )
                    .text( options.closeText )
                    .appendTo( uiDialogTitlebarClose ),

                uiDialogTitle = $( "<span>" )
                    .addClass( "ui-dialog-title" )
                    .attr( "id", titleId )
                    .html( title )
                    .prependTo( uiDialogTitlebar );

            uiDialogTitlebar.find( "*" ).add( uiDialogTitlebar ).disableSelection();
            //this._hoverable( uiDialogTitlebarClose );
            //this._focusable( uiDialogTitlebarClose );

            if ( options.draggable && $.fn.draggable ) {
                self._makeDraggable();
            }
            if ( options.resizable && $.fn.resizable ) {
                self._makeResizable();
            }

            self._createButtons( options.buttons );
            self._isOpen = false;

            if ( $.fn.bgiframe ) {
                uiDialog.bgiframe();
            }
        },
        _createButtons: function( buttons ) {
            var self = this,
                hasButtons = false;

            // if we already have a button pane, remove it
            self.uiDialogOriginal.find( ".ui-dialog-buttonpane" ).remove();

            if ( typeof buttons === "object" && buttons !== null ) {
                $.each( buttons, function() {
                    return !(hasButtons = true);
                });
            }
            if ( hasButtons ) {
                var uiDialogButtonPane = $( "<div>" )
                        .addClass( "ui-dialog-buttonpane  ui-widget-content ui-helper-clearfix" ),
                    uiButtonSet = $( "<div>" )
                        .addClass( "ui-dialog-buttonset" )
                        .appendTo( uiDialogButtonPane );

                $.each( buttons, function( name, props ) {
                    props = $.isFunction( props ) ?
                        { click: props, text: name } :
                        props;
                    var button = $( "<button type='button'>" )
                        .attr( props, true )
                        .unbind( "click" )
                        .click(function() {
                            props.click.apply( self.element[0], arguments );
                        })
                        .appendTo( uiButtonSet );
                    if ( $.fn.button ) {
                        button.button();
                    }
                });
                self.uiDialogOriginal.addClass( "ui-dialog-buttons" );
                uiDialogButtonPane.appendTo( self.uiDialogOriginal );
            } else {
                self.uiDialogOriginal.removeClass( "ui-dialog-buttons" );
            }
        }
    });

}( jQuery ) );

这是我的使用方法: 问题似乎是 $(this).dialog('close'); 根本不调用 close 函数......

    var btns = {};
    btns[$.i18n.prop('buttons.ok')] = function() {
        $(this).dialog('close');
    };

    var opt = options || {};

    if(opt.open==undefined)
        opt.open = true;

    $dialog = $('<div class="0m4r"></div>');
    $dialog.mydialog({
        title: opt.title || '',
        bgiframe: opt.bigFrame || true,
        modal: opt.modal!=undefined?opt.modal:glbmodal,
        overlay :{
            backgroundColor :'#000',
            opacity :0.8
        },
        buttons: opt.buttons || btns,
        width: opt.width || $(document).width()/2,
        height: opt.height || $(document).height()/2,
        position: 'center',
        autoOpen: opt.open, 
        close: function(){
            $(this).dialog('destroy');
            $(this).remove();
            $('.dialog').filter(function(){
                if ($(this).text() == "")
                {
                    return true;
                }
                return false;
            }).remove();
        }
    });


    if(opt.content){
        $dialog.html(opt.content);
    }
    return $dialog;
};

谢谢!

I am trying with the code below to extend jQueryUI Dialog to get to something like this:http://www.schillmania.com/projects/dialog/png/

Everything works fine except the fact that when I click the button to close the dialog nothing happens.

(function( $, undefined ) {

    var uiDialogClasses = "ui-dialog ui-widget ui-widget-content roundbox";

    $.widget("custom.mydialog", $.ui.dialog, {

        _super_create: $.ui.dialog.prototype._create,
        _create: function() {
            this.originalTitle = this.element.attr( "title" );
            // #5742 - .attr() might return a DOMElement
            if ( typeof this.originalTitle !== "string" ) {
                this.originalTitle = "";
            }       
            this.oldPosition = { 
                parent: this.element.parent(), 
                index: this.element.parent().children().index( this.element ) 
            };
            this.options.title = this.options.title || this.originalTitle;
            var self = this,
                options = self.options,

                title = options.title || " ",
                titleId = $.ui.dialog.getTitleId( self.element ),

                uiDialog = ( self.uiDialogOriginal = $( '<div class="lbasDialog">' ) )
                    //.addClass( uiDialogClasses + options.dialogClass)
                    // setting tabIndex makes the div focusable
                    .attr( "tabIndex", -1)
                    .keydown(function( event ) {
                        if ( options.closeOnEscape && !event.isDefaultPrevented() && event.keyCode &&
                                event.keyCode === $.ui.keyCode.ESCAPE ) {
                            self.close( event );
                            event.preventDefault();
                        }
                    })
                    .attr({
                        role: "dialog",
                        "aria-labelledby": titleId
                    })
                    .mousedown(function( event ) {
                        self.moveToTop( false, event );
                    })
                    .appendTo( "body" )
                    .wrap('<div class="dialog"><div class="bd"><div class="c"><div class="s"></div></div></div></div>')

                    self.uiDialog = $('div.dialog');

                     $('div.dialog')
                       .prepend('<div class="hd">'+
                         '<div class="c"></div></div>')
                       .append('<div class="ft">'+
                         '<div class="c"></div></div>')
                       .addClass( uiDialogClasses + options.dialogClass);



                uiDialogContent = self.element
                    .show()
                    .removeAttr( "title" )
                    .addClass( "ui-dialog-content ui-widget-content" )
                    .appendTo( uiDialog ),

                uiDialogTitlebar = ( self.uiDialogTitlebar = $( "<div>" ) )
                    .addClass( "ui-dialog-titlebar  ui-widget-header  " +
                        "ui-corner-all  ui-helper-clearfix" )
                    .prependTo( uiDialog ),

                uiDialogTitlebarClose = $( "<a href='#'></a>" )
                    .addClass( "ui-dialog-titlebar-close  ui-corner-all" )
                    .attr( "role", "button" )
                    .click(function( event ) {
                        event.preventDefault();
                        self.close( event );
                    })
                    .appendTo( uiDialogTitlebar ),

                uiDialogTitlebarCloseText = ( self.uiDialogTitlebarCloseText = $( "<span>" ) )
                    .addClass( "ui-icon ui-icon-closethick" )
                    .text( options.closeText )
                    .appendTo( uiDialogTitlebarClose ),

                uiDialogTitle = $( "<span>" )
                    .addClass( "ui-dialog-title" )
                    .attr( "id", titleId )
                    .html( title )
                    .prependTo( uiDialogTitlebar );

            uiDialogTitlebar.find( "*" ).add( uiDialogTitlebar ).disableSelection();
            //this._hoverable( uiDialogTitlebarClose );
            //this._focusable( uiDialogTitlebarClose );

            if ( options.draggable && $.fn.draggable ) {
                self._makeDraggable();
            }
            if ( options.resizable && $.fn.resizable ) {
                self._makeResizable();
            }

            self._createButtons( options.buttons );
            self._isOpen = false;

            if ( $.fn.bgiframe ) {
                uiDialog.bgiframe();
            }
        },
        _createButtons: function( buttons ) {
            var self = this,
                hasButtons = false;

            // if we already have a button pane, remove it
            self.uiDialogOriginal.find( ".ui-dialog-buttonpane" ).remove();

            if ( typeof buttons === "object" && buttons !== null ) {
                $.each( buttons, function() {
                    return !(hasButtons = true);
                });
            }
            if ( hasButtons ) {
                var uiDialogButtonPane = $( "<div>" )
                        .addClass( "ui-dialog-buttonpane  ui-widget-content ui-helper-clearfix" ),
                    uiButtonSet = $( "<div>" )
                        .addClass( "ui-dialog-buttonset" )
                        .appendTo( uiDialogButtonPane );

                $.each( buttons, function( name, props ) {
                    props = $.isFunction( props ) ?
                        { click: props, text: name } :
                        props;
                    var button = $( "<button type='button'>" )
                        .attr( props, true )
                        .unbind( "click" )
                        .click(function() {
                            props.click.apply( self.element[0], arguments );
                        })
                        .appendTo( uiButtonSet );
                    if ( $.fn.button ) {
                        button.button();
                    }
                });
                self.uiDialogOriginal.addClass( "ui-dialog-buttons" );
                uiDialogButtonPane.appendTo( self.uiDialogOriginal );
            } else {
                self.uiDialogOriginal.removeClass( "ui-dialog-buttons" );
            }
        }
    });

}( jQuery ) );

here is how I do use it:
and the issue seems to be that $(this).dialog('close'); dose not call the close function at all....

    var btns = {};
    btns[$.i18n.prop('buttons.ok')] = function() {
        $(this).dialog('close');
    };

    var opt = options || {};

    if(opt.open==undefined)
        opt.open = true;

    $dialog = $('<div class="0m4r"></div>');
    $dialog.mydialog({
        title: opt.title || '',
        bgiframe: opt.bigFrame || true,
        modal: opt.modal!=undefined?opt.modal:glbmodal,
        overlay :{
            backgroundColor :'#000',
            opacity :0.8
        },
        buttons: opt.buttons || btns,
        width: opt.width || $(document).width()/2,
        height: opt.height || $(document).height()/2,
        position: 'center',
        autoOpen: opt.open, 
        close: function(){
            $(this).dialog('destroy');
            $(this).remove();
            $('.dialog').filter(function(){
                if ($(this).text() == "")
                {
                    return true;
                }
                return false;
            }).remove();
        }
    });


    if(opt.content){
        $dialog.html(opt.content);
    }
    return $dialog;
};

Thanks!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

执手闯天涯 2025-01-11 14:49:57

我认为你的问题是你用“this”引用了错误的变量。

btns[$.i18n.prop('buttons.ok')] = function() {
    $(this).dialog('close');
};

这里的 $(this) 选择器是从按钮数组中选择按钮,我认为这不是您想要完成的任务,因为您的按钮没有附加对话框。您需要引用对话框本身来关闭它,如下所示。

  $($dialog).dialog('close');

I think your problem is that you are referencing the wrong variable with "this".

btns[$.i18n.prop('buttons.ok')] = function() {
    $(this).dialog('close');
};

The $(this) selector here is selecting the button from your array of buttons, which I don't think is what you are trying to accomplish as your buttons don't have a dialog attached. You need to reference the dialog itself to close it, something like this.

  $($dialog).dialog('close');
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文