2009-10-25 6 views

risposta

10

Intendi lo jQuery UI dialog widget?

È possibile passare un'opzione quando la si crea per specificare la sua altezza, ad es.

$('.selector').dialog({ height: 350 }); 

Renderlo più alto del contenuto che stai mettendo in esso, e ho il sospetto che saresti d'oro.

4

Non so esattamente cosa si intende per una 'finestra di dialogo jQuery', ma il modo standard per disattivare le barre di scorrimento potrebbe essere quella di impostare la proprietà di overflow del div a 'nascosto'

mettere questo nel vostro file css:

div.class_name { 
    overflow: hidden; 
} 
+0

jquery (un wrapper javascript di sorta) ha le proprie finestre di dialogo. ci sono opzioni in jQuery per fare cose simili ma non ne trova una per questo particolare plugin. non posso semplicemente impostare quella proprietà per jquery – ngreenwood6

+3

jquery non è un wrapper javascript, è un framework che astrae i problemi di cross-browser e semplifica l'attraversamento DOM ... se puoi specificare quale funzione jquery stai usando per generare la 'finestra di dialogo' allora potrei essere in grado di aiutare ... –

+2

Non sono sicuro del motivo per cui questo è stato downvoted così tanto quando è il modo corretto di fare le cose. '.ui-dialog-content {overflow: hidden; } 'per disabilitare le barre di scorrimento in tutte le finestre di dialogo. '#myDialogID {overflow: nascosto; } 'per solo uno. –

63

ho risolto il problema in questo modo:

.dialog({ 
    title: $(this).attr("data-dialog-title"), 
    closeOnEscape: true, 
    close: function() { $(this).remove() }, 
    draggable: true, 
    position: 'center', 
    width: 500, 
    height: 'auto', 
    modal: true, 
    open: function (event, ui) { 
    $('#myDialogId').css('overflow', 'hidden'); //this line does the actual hiding 
    } 
}); 
+1

Puoi spiegare cosa hai fatto per disabilitare la barra di scorrimento ? –

+0

Oh, capisco .. grazie! –

+5

Semplicemente lanciando una rapida correzione per i commentatori di questa particolare risposta (che ho usato grazie a uomo btw). Ciò che rimuove le barre di scorrimento sta nascondendo il trabocco con quel trucco css, molto lucido.Questa parte fa il nascondiglio: "open: function (event, ui) { $ ('# myDialogId'). Css ('overflow', 'hidden'); }" – unrealtrip

2

L'overflow: hidden lavorato per me. Quando si impostano solo i parametri altezza/larghezza, le barre di scorrimento appaiono ancora a seconda delle dimensioni del testo e dello zoom.

1

Questa rimosso le barre di scorrimento:

$("#dialog").dialog({ 
    autoOpen: false, 
    resizable: false, 
    dialogClass: 'info', 
    height: 'auto', 
    width: 'auto', 
    show: { effect: "blind", duration: 1000 }, 
    hide: {effect: "explode", duration: 1000 }, 
    draggable: true, 
    open: function (event, ui) { 
     $(this).dialog('open'); 
    }, 
    close: function (event, ui) { 
     cleanup() ; 
    } 
}); 
2

Soluzione senza CSS o fisso Altezza:

Penso che la soluzione migliore per problema di cui sopra è quello di rendere dialogo altezza dinamica, l'altezza dovrebbe regolare automaticamente come per il contenuto, quando il contenuto aumenta l'altezza modale dovrebbe aumentare. Per fare questo utilizzare l'opzione altezza "auto" fornito da jQuery UI modale, si regola l'altezza modale come per il contenuto in modo da necessità di add 'overflow: hidden' o 'altezza: 350'

$("#dialog").dialog({ 
modal : true, 
height:"auto" 

}); 
0

Nell'esempio sottostante Ho anche aggiunto 'resizable = false' per la finestra di dialogo. In modo che qualsiasi testo di overflow non possa essere visto ridimensionando la finestra di dialogo.

$("a#registerServerStudio , a#regServer").click(function(e) { 
    //alert("login using POST is Clicked"); 
    e.preventDefault(); 
    registerSuccess = false; 

    regSSDlg = $("#regSS").dialog({ 
     autoOpen: false, 
     height: 280, 
     width: 420, 
     modal: true, 
    resizable: false, 
     buttons: { 
     }, 
     close: function() { 
     registerSuccess = false; 
     }, 
    show:{effect:'bounce', duration: 100}, 

    }); 
    $('#regSS').css('overflow', 'hidden'); 
    regSSDlg.prev(".ui-dialog-titlebar").css({"background":"#47669E", "color":"white", "font-size":"13px", "font-weight":"normal"}) ; 

    regSSDlg.dialog("open"); 
});