每个用户会话运行一次javascript?

时间:2013-02-04 19:52:09

标签: php javascript html

我有这个javascript,如果用户点击我的搜索表单中的文本区域,则会显示div。

基本上是在使用

将搜索表单拉到主页的那一刻
<?php include(); ?>

当用户在主页上时,他们点击文本区域并显示div,然后他们离开文本区域(onblur)并隐藏div。这个功能只发生一次,不会再发生。

然而,一旦用户点击搜索并且提交了搜索,则该功能再次启动,因此用户点击文本区域并显示div,它们会脱离它并隐藏它。和以前一样只发生过一次。

我不希望每次用户点击文本字段时显示div,我只希望他们看到这个div一次,无论他们在网站上的页面是什么。

我已将javascript放入search.php文件中,该文件已拉到主页上,并放到我网站上的其他每个页面上。

这可能就是为什么功能会在每个新页面上发生,但我希望用户能够从网站上的任何位置访问搜索栏,以及他们是否从那里开始搜索home.php或个人资料.php或任何其他页面我希望div只向用户显示一次,而不是再次显示整个会话或cookie会话。

这是可能的,有人可以告诉我怎么样?

感谢

<script>

        $(function() {
            $(".search_prompt").hide();
            var focusin_flag = false,
                focusout_flag = false;
            $("#text").focusin(function() {
                if (!focusin_flag) {
                    $(".search_prompt").show();
                    focusin_flag = true;
                }
            }).focusout(function () {
                if (!focusout_flag ) {
                    $(".search_prompt").hide();
                    focusout_flag = true;
                } 
                function timeout_init() {
        setTimeout('search_prompt()', 2000);

                }
            });
        });
    </script>

搜寻脚本:

<form method="get" action="">
    <input type="hidden" name="dosearch" value="1">
    <input type="text" id="text" name="query" class="searchbox" placeholder="Search Name/Location" style="width:120px;"/>
    <input type="image" src="../PTB1/assets/img/icons/search.png" height="19" width="20" class="searchbutton" name="submit" value="Start Search" />
</form>

<?php
//PHP CODE STARTS HERE

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

// Change the fields below as per the requirements
$db_host="localhost";
$db_username="root";
$db_password="";
$db_name="";
$db_tb_atr_name="display_name";

//Now we are going to write a script that will do search task
// leave the below fields as it is except while loop, which will display results on screen

mysql_connect("$db_host","$db_username","$db_password");
mysql_select_db("$db_name");

$query=mysql_real_escape_string($_GET['query']);


$query_for_result=mysql_query("SELECT *,MATCH(display_name, location, sex, ethnicity, hobbies, station, age, weight_st, weight_lb, height_ft, height_in, build) AGAINST ('$query' IN BOOLEAN MODE) AS relevance FROM ptb_stats WHERE MATCH(display_name, location, sex, ethnicity, hobbies, station, age, weight_st, weight_lb, height_ft, height_in, build) AGAINST('$query' IN BOOLEAN MODE) ORDER BY relevance DESC LIMIT 5");
echo "<div class=\"search-results\">";
while($data_fetch=mysql_fetch_array($query_for_result))

{

    echo "<div class=\"text\"><a href=\"profile.php?id={$data_fetch['user_id']}\" class=\"search\">";
    echo "<div class=\"spacing\"><img width=35px height= 30px src=\"data/photos/{$data_fetch['user_id']}/_default.jpg\" class=\"boxgridsearch\"/> "; 
     echo substr($data_fetch[$db_tb_atr_name], 0,160);
    echo "</a></div></div>";

}
echo "<div class=\"morebutton-search\"><a href=\"search_results.php?query=$query\" \">+ view more results</a></div>";




mysql_close();
}

?>

1 个答案:

答案 0 :(得分:2)

这不理想,但我建议在用户第一次点击该页面时设置$_SESSION变量(或执行您只想执行一次的任何操作)。然后,在包含JavaScript之前,检查是否设置了该会话变量。如果是这样,请不要包含JavaScript。如果没有,请加入它。

它看起来像这样:

// User just performed action for the first time.
$_SESSION['saw_div'] = true;

然后,后来:

<?php if (!isset($_SESSION['saw_div']) || $_SESSION['saw_div'] == false): ?>
    <script>
        // Include your JS script
    </script>
<?php endif; ?>