0

前の質問で問題を解決したと思っていましたが、うまくいきません。管理者がボタンをクリックした場合、php 変数 (var b1 および var b2 によって呼び出される $start および $end) を変更したいと考えています。この後、すべての訪問者が新しいコードを利用できるようになるため、サーバー要求を行う必要があります。これが私の更新されたコードです:

<?php
  if(date('w') == 4){ // day 2 = Tuesday

$start = strtotime('9:30');
$end = strtotime('12:30');
$timenow = date('U'); 
if ($timenow >= $start && $timenow <= $end) { 
 echo'<div id="iar_eu">';
echo quick_chat(200, 'default', 1, 'left', 0, 0, 1, 1, 1);
 echo'</div>';
 } } 
 ?>

</div>



<?php if ( is_user_logged_in() ) { ?>
<input type="submit" value="Start Chat" id="start_chat" style="position: absolute; top: 30px; left: 10px;" />
<?php
 } ?> 

  <script type="text/javascript">



if(jQuery('#start_chat').data('clicked')) {
   // change var b1 and b2
  $.ajax({
    type: "POST",
    url: "/web/htdocs/www.fattorefamiglia.com/home/wp-content/themes/child_care_creative/chat.php",
    dataType: 'json',
    data: { b1: "1:00", b2: "23:00" }
}).done(function(data) {
    b1 = data.b1;
    b2 = data.b2;
});}

else {
   $.ajax({
    type: "POST",
    url: "/web/htdocs/www.fattorefamiglia.com/home/wp-content/themes/child_care_creative/chat.php",
    dataType: 'json',
    data: { b1: "9:00", b2: "18:00" }
}).done(function(data) {
    b1 = data.b1;
    b2 = data.b2;
});}



jQuery('#start_chat').click(function(){
  $(this).data('clicked', true);

  var b1 = '<?php echo $start; ?>';
  var b2 = '<?php echo $end; ?>';

});


</script>

チャット.php:

<?php
// variables
if (!empty($_POST)) {
    $data['b1'] = $_POST['b1'];
    $data['b2'] = $_POST['b2'];
}

// to not lose them
$_SESSION['chat'] = $data;

// to keep it compatible with your old code
$start = $data['b1'];
$end = $data['b2'];

// send the JSON formatted output
echo json_encode($data);

?>

ボタンをクリックしても何も起こりません。私は何を間違っていますか?

4

2 に答える 2

2

jQuery の使用方法に問題があります。すべての jQuery 参照は、ページの準備ができた後にのみ呼び出される関数で作成するか、ページの準備ができていることを確認するラッパーで作成する必要があります。

たとえば、次のコードはラップする必要があります。

jQuery('#start_chat').click(function(){
  $(this).data('clicked', true);
  var b1 = '<?php echo $start; ?>';
  var b2 = '<?php echo $end; ?>';
});

このような:

jQuery(function(){
  jQuery('#start_chat').click(function(){
    $(this).data('clicked', true);
    var b1 = '<?php echo $start; ?>'
    var b2 = '<?php echo $end; ?>';
  });
});

を設定して.data()も、ここでは何の役にも立ちません。その方法が機能するため、要素ではなく実際の var に情報を設定しています。

しかし、AJAX リクエストの作成方法には別の問題があります。単に if ステートメントをそこに置くだけでは、それが実現しません。アクションを実際に実行するには、リスナーが必要です。しかし、それに入るのではなく、単純化してこのようにしてみませんか?

<script type="text/javascript">
var b1 = '<?= $start ?>', b2 = '<?= $end ?>';

$(function(){
  $('#start_chat').click(function(){
        $.post('/web/htdocs/www.fattorefamiglia.com/home/wp-content/themes/child_care_creative/chat.php', { b1: '1:00', b2: '23:00' }, 
            function(data) {
                b1 = data.b1;
                b2 = data.b2;
            }, 'json');
  });
});
</script>
于 2012-09-20T15:15:14.413 に答える
1

この行

if(jQuery('#start_chat').data('clicked')) { 

.data('clicked')がクリックされるまで設定されないため、真になることはありません#start_chat。これは、チェックが行われた後に常に発生します。

達成したいことのプロセスを再考する必要があります。

于 2012-09-20T15:00:05.480 に答える