0

我正在创建一个简单的 PHP 页面,该页面读取 CSV 文件内容并在页面中向用户显示一些选定的列 目前,我正在读取每一行并立即显示它。由于这种方法,我只知道读完整个文件后的总行数(也在文件中搜索)。我想要的是在列表的顶部和底部显示两个页面导航。像这样:

第 1|2|3|4 页


字段 1|字段 2|字段 3|字段 4|字段 5....|字段 n

第 1 行

第 2 行

……

罗恩


第 1|2|3|4 页

显示所有行后,底部页面导航,我使用 jquery 函数: insertBefore 将另一个页面导航插入顶部。

问题是:

1) IE8 中不显示首页导航,但按 F5 后显示(在 FF、Chrome 中工作)。

2) 使用 insertBefore 函数,在显示底部导航后,顶部导航突然弹出。看起来不自然

有什么建议吗?

源代码:

为了简单起见,我重写了这两个简单的源文件。
-FileList.php:列出所有 csv 文件 -DisplayInList.php
:显示 CSV 文件内容

顺便说一句:我已经通过更改 FileList.php 中的 jquery 代码解决了这个问题

            FileList.php
            <?php
                    echo "<script type=\"text/javascript\">\n";
                    echo "$(document).ready(function(){\n";
                    echo "$('a[name=dlink]').click(function(e) {\n";
                    echo "    e.preventDefault();\n";
                    echo "    var href = $(this).attr('href');\n";
                    echo "    $.post('DisplayInList.php',{href:href}, function(response)\n";
                    echo "     list_window = window.open()\n";
                    echo "     list_window.document.write(response);\n";
                    echo "     list_window.focus();\n";
                    echo "     list_window.document.close();\n";
                    echo "    });\n";
                    echo " });\n";
                    echo "});\n";
                    echo "</script>\n";


                    //add CSV file link here
                    foreach($file_list as $f){
                        $display_name = "WHATEVER";
                        echo "<TR><TD><a name=\"dlink\" href=",pathinfo($f,PATHINFO_FILENAME),">",$disp_name,"</a></TD>\n";
                    }
            ?>

            DisplayInList.php

            <?php
                echo "<div id=\"paging_tag\"></div>\n";
                if (($handle = fopen($csv_file, "r")) !== FALSE){
                    $display_cnt = 0;
                    while (($line = fgetcsv($handle, 10000, ",")) !== FALSE){
                        $found = {Check search conditions};
                        if ( $found == true ){
                            $display_cnt++;
                            //Display line to client
                            echo "Selected fields of a csv line to user";
                        }
                    }
                    fclose($handle);
                }

                if ( $display_cnt > 0 ){
                    echo "<p id=\"paging\"><span>PREVIOUS</span> Page 1 | Page 2 | Page 3<span>NEXT</span></p>";
                }

                echo "<script type=\"text/javascript\">\n";
                echo "$('#paging')\n";
                echo "          .insertBefore('#paging_tag');\n";
                echo "</script>";
            ?>
4

1 回答 1

0

使用 js 构建 UI 是最不优先的方法。只要可以使用服务器端和 HTML/CSS 方法,就避免使用 javascript。

我建议使用 PHP,例如:

$pagerHtml = 'do some code here';
print $pagerHtml; //the first place on top
/*
...
output HTML between the two pager lines
...
*/
print $pagerHtml //the bottom pager line
于 2012-06-03T07:21:09.010 回答