0

每当触发事件时,我都会尝试分配一个会话变量(在此处使用 Javascript)。但是我没能做到这一点,所以它是在我的页面正文加载之后加载的,而不是像按下按钮那样生成的 after 事件。

我有两个页面:一个是检查会话变量是否设置。如果是,则执行该操作并销毁它。

另一个是一个巨大的页面,它作为子页面包含在其中(使用include),它是一个表单,它被提交给自己,使其重新加载。现在,无论何时生成事件(例如按下提交按钮和单击按钮),该子页面都会设置一个会话。

first.php --> 会话检查和销毁 second.php --> 会话初始化和分配

两者都是迭代的。

我可以使用后端来存储数据,但是那个大页面有一些限制,不能在其中包含其他数据库。

第一个.php

<?php
    session_start();
    print_r($_SESSION);
    var_dump($_SESSION);

    if(isset($_SESSION['submit']) && isset($_SESSION['click']) ) {
        echo "passed both tests";
        unset($_SESSION['submit']);
        unset($_SESSION['click']);
        session_destroy():
    }
    var_dump($_SESSION);
    print_r($_SESSION);
    var_dump($_SESSION);
?>

second.php(表格)

<?php
    session_start();
?>
<html>
  <head>
    <meta name="generator" content="HTML Tidy for Windows (vers 14 February 2006), see www.w3.org">
    <script type="text/javascript">
        function submit_valid(){
            <?php
                $_SESSION['submit']='yes';
            ?>

        }
    </script>
    <script type="text/javascript">
        function click_valid1(){
            document.getElementById('submitButton').disabled=true;
            <?php
                $_SESSION['click']='clicked';
            ?>

            window.location.replace("first.php");
        }
    </script>
    <script type="text/javascript">
        function load_valid3(){
            <?php
                $_SESSION['submit']='no';
                $_SESSION['clicked']='not';
            ?>
        }
    </script>

    <script type="text/javascript">
        setTimeout (function(){
            document.getElementById('submitButton').disabled = null;
        },10000);
        var countdownNum = 10;
        incTimer();
        function incTimer(){
            setTimeout (function(){
                if(countdownNum != 0){
                    countdownNum--;
                    document.getElementById('timeLeft').innerHTML = 'Time left: ' + countdownNum + ' seconds';
                    incTimer();
                } else {
                    document.getElementById('timeLeft').innerHTML = 'Ready!';
                }
            },1000);
        }
    </script>

    <title></title>
  </head>
  <body onload="return load_valid3()">
    <form action="search.php" method="get" onsubmit="return submit_valid()">
      <table border="2" width="150" cellpadding="0" cellspacing="2">
        <tr>
          <td align="center">
            <input type="text" id="query" name="query" size="30" value="">
          </td>
          <td align="center">
            <input type="submit" value="Search"> <input type="hidden" name="search" value="1">
          </td>
        </tr>
        <tr>
          <td align="center">
            <input type="button" value="SUBMIT" disabled="disabled" id="submitButton" onclick="return click_valid1()">
          </td>
          <td align="center">
            <p id="timeLeft">
              Time Left: 10 seconds
            </p>
          </td>
        </tr>
      </table>
    </form>
  </body>
</html>

PHP中有静态变量的概念吗?这样我就可以摆脱这种情况。

4

2 回答 2

0

尽管真的不知道你要去哪里:

使用jQuery,我示例性地实现了您的第一个 JS 函数“ valid()”:

function valid() {
    $.ajax({
        type: "POST",
        url: "first.php",
        data: {
            "color": "red"
        }
    });
}

这就是您更新会话变量的方式。

$_SESSION['color'] = $_REQUEST['color']

我仍然没有真正看到“有效”功能的意义是什么,但也许这会告诉你你可以去哪里。

于 2013-06-01T05:57:20.370 回答
0

尝试将 javascript 函数调用与表单提交操作分开。您可以使用“isset 函数”和“if 条件语句”来检查表单是否提交。就像是:

if(isset($_GET['submit']))
{

}
于 2013-06-01T05:51:59.310 回答