来自php循环的Jquery-ui打开对话框

时间:2014-03-30 10:30:28

标签: php jquery jquery-ui

可能有很多方法可以实现我想做的事情,但我只需要最简单的方法。 我使用php for循环来显示db的数据。 我想显示数据库中的对话框,该对话框更改值以匹配php for循环值。现在它只显示数据库中的最后一行值。

$(this).parent()。submit();是因为我从另一个工作解决方案中复制了它:)

这是我尝试过但对话框只显示最后一行且ID没有变化。 PHP:

for ($i=0; $i < $numrows ; $i++){
echo ('<div style="float: left; min-height: 20px; font-size: 14px; width: 266px;
padding-left: 5px;" class="emailTopicStyle"><a class="show" name="id" value="'.$id.'" href="#">'.$topic.'</a></div>');

echo ('<div style="float: left; padding-left: 20px; 
font-size: 14px; min-height: 20px;" class="emailTopicStyle">'.$body.'</div>');

 }

}
echo ('<div id="dialog-open" title="Sent, '.$sent.'">');
echo ('<p style="line-height: 1.2em; font-weight: bold; padding-bottom: 8px;"><span class="ui-icon ui-icon-mail-closed" style="float: left; margin: 0 7px 20px 0; "></span>Aihe: '.$topic.'</p>');
echo ('<p style="line-height: 1.2em;"><span style="float: left;"></span>Body: '.$body.'</p>');
echo ('</div>'); 
echo ('<div style="clear: both;">&nbsp;</div>').PHP_EOL;    

Jquery的:

var formvalue ='';
    $( "#dialog-open" ).dialog({
      resizable: true,
      height:300,
      width: 600,
      modal: true,
      autoOpen: false,
      buttons: {
        "Sulje": function() {
            $('[name=id]').each(function() {
            if (formvalue == $(this).val()) {
                $(this).parent().submit();
            }
            });
            $( this ).dialog( "close" );        
        }
      }
    });


 $( ".show" ).click(function() {
 formvalue = $(this).parent().find('[name=id]').val();
 $( "#dialog-open" ).dialog( "open" );
})

结果html:

This is testsubject Testaillaan numero 1.. 30.03.2014 09:30:20 2868
This is testsubject Testaillaan numero 2.. 30.03.2014 09:30:33 2869
This is testsubject Ja lisää testiä.. 30.03.2014 14:31:31 2870

as html:

<div style="float: left; min-height: 20px; font-size: 14px; width: 266px; padding-left: 5px; margin-bottom: 2px;" class="emailTopicStyle"><a class="show" name="id" value="2" href="#">Tämä on testiotsikko</a></div><div style="float: left; padding-left: 20px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">Testaillaan numero 1..</div><div style="float: left; padding-left: 20px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">30.03.2014 09:30:20</div><div style="float: left; padding-left: 20px; padding-right: 10px; font-size: 14px; min-height: 20px;" 

class="emailTopicStyle">2868</div>
<div style="float: left; min-height: 20px; font-size: 14px; width: 266px; padding-left: 5px; margin-bottom: 2px;" class="emailTopicStyle"><a class="show" name="id" value="3" href="#">Tämä on testiotsikko</a></div><div style="float: left; padding-left: 20px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">Testaillaan numero 2..</div><div style="float: left; padding-left: 20px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">30.03.2014 09:30:33</div><div style="float: left; padding-left: 20px; padding-right: 10px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">2869</div>

</div><div style="float: left; min-height: 20px; font-size: 14px; width: 266px; padding-left: 5px; margin-bottom: 2px;" class="emailTopicStyle"><a class="show" name="id" value="4" href="#">Tämä on testiotsikko</a></div><div style="float: left; padding-left: 20px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">Ja lisää testiä..</div><div style="float: left; padding-left: 20px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">30.03.2014 14:31:31</div><div style="float: left; padding-left: 20px; padding-right: 10px; font-size: 14px; min-height: 20px;" class="emailTopicStyle">2870</div>

BR, Toube

1 个答案:

答案 0 :(得分:0)

尝试更改行

formvalue = $(this).parent().find('[name=id]').val();

formvalue = $(this).parent().find('[name=id]').attr('value');

修改

我已经完成了我认为你期待的事情。您可以从中激励您做您想做的事:http://jsfiddle.net/cYEsp/2/