Вопрос

Я хотел бы знать, могу ли я использовать следующую функцию JQuery для идентификатора элемента, расположенного в диалоге JQuery.

$('#idofmyfield').val()

Ничего не вернул.

Это было полезно?

Решение

Возможно, вам потребуется настроить идентификатор селектора в соответствии с разметкой, сгенерированной диалоговым окном:

<div class="ui-dialog ui-widget ui-widget-content ui-corner-all ui-draggable ui-resizable">
   <div class="ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix">
      <span id="ui-dialog-title-dialog" class="ui-dialog-title">Dialog title</span>
      <a class="ui-dialog-titlebar-close ui-corner-all" href="#"><span class="ui-icon ui-icon-closethick">close</span></a>
   </div>
   <div style="height: 200px; min-height: 109px; width: auto;" class="ui-dialog-content ui-widget-content" id="dialog">
      <p>Dialog content goes here.</p>
   </div>
</div>

возможно, сделайте это:

$('div.ui-widget-content > #idofmyfield').val(); 

У меня была похожая ситуация, когда я извлекал данные JSON, чтобы заполнить диалог. Мой код, который работает, выглядит следующим образом:

if (jQuery) {
    jQuery(document).ready(function(){                      
        jQuery('#dialog').dialog({
            autoOpen: false,
            modal: true,
            width: 690, 
            position: [160, 160]
        }); /* end #dialog */

   /* do some processing and add the following to a click method */
    jQuery.getJSON(json_link, function(json){
        jQuery('.ui-dialog-title').text(json.title);
        jQuery('.ui-dialog-content').html(json.html);
    });

    jQuery('#dialog').dialog('open');
   /* end of click method */


}); /* end document.ready */
}

Другие советы

посмотрите на события для диалога

$('.yourDialog').dialog({
   close: function(event, ui) {
       alert($('#idofmyfield').val());
   }
});
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top