php - 单击时发出服务器请求以更改 php 变量

标签 php javascript jquery html

我以为我解决了上一个问题中的问题,但它仍然不起作用。如果管理员单击按钮,我想更改 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);

?>

当我点击按钮时没有任何反应。我做错了什么?

最佳答案

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>

关于php - 单击时发出服务器请求以更改 php 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12515182/

相关文章:

javascript - _leaflet_id 在 onEachFeature 函数中返回 undefined

javascript - Bootstrap datepicker 在通过 javascript 函数放在页面上时不起作用

javascript - 处理背景色覆盖时边框底部不起作用

php - 将 PHP 变量从 Button 传递到 Javascript 函数

php - DB::Table 和 DB::Select 之间的区别

php - 如何使用wpdb(wordpress数据库)做小于、大于?

javascript - AngularJS UI-router - 如何区分 url 部分和 url 参数?

java - .jar 文件未安装在三星手机上,但安装在诺基亚上

javascript - 单击添加行 td 并自动完成

javascript - jQueryUI 和 jQuery 插件冲突