Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/267.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 函数中的变量未定义_Php_Mysql_Function - Fatal编程技术网

Php 函数中的变量未定义

Php 函数中的变量未定义,php,mysql,function,Php,Mysql,Function,我将整个分页脚本放入一个函数中,以便可以多次使用它。代码很长,但只有一部分我有问题 调用函数paginate($connection,“categories”)我使用 $sql = "SELECT * FROM categories ORDER BY cat_name LIMIT $start, $limit"; etc.. 我得到了这些错误 注意:未定义变量:start 注意:未定义变量:限制您 SQL语法有错误; 检查相应的手册 您的MySQL服务器版本 在第1行的“”附近使用的语法正确

我将整个分页脚本放入一个函数中,以便可以多次使用它。代码很长,但只有一部分我有问题

调用函数
paginate($connection,“categories”)我使用

$sql = "SELECT * FROM categories ORDER BY cat_name LIMIT $start, $limit";

etc..
我得到了这些错误

注意:未定义变量:start 注意:未定义变量:限制您 SQL语法有错误; 检查相应的手册 您的MySQL服务器版本 在第1行的“”附近使用的语法正确

它没有识别我在查询上面调用的函数中的变量。我以前从未在函数中放过这么多代码,所以我不确定我必须做什么。我尝试返回那些未定义的变量(在函数中),但没有成功。。我还试图避免使用globals——我听说它们已经被弃用了

下面是实际的功能

function paginate($connection, $tableName) {

//Pagination
$targetpage = "http://localhost/website/all_categories.php";    
$limit = 4; //sets how many rows to display on each page

//count rows
$sql = "SELECT COUNT(*) as num FROM $tableName";
$total_pages = $connection->query($sql) or die(mysqli_error($connection)); 
$row = $total_pages->fetch_assoc();
$total_pages = $row['num'];

//if there's no page number, set it to the first page
$stages = 3;
$page = isset($_GET['page']) ? $_GET['page'] : 0;
$start = empty($page) ? $start = 0 : $start = ($page - 1) * $limit;

// Initial page num setup
    if ($page == 0){$page = 1;}
    $prev = $page - 1;  
    $next = $page + 1;                          
    $lastpage = ceil($total_pages/$limit);      
    $LastPagem1 = $lastpage - 1;                    


    $paginate = '';
    if($lastpage > 1)
    {   

        $paginate .= "<div class='paginate'>";
        // Previous
        if ($page > 1){
            $paginate.= "<a href='$targetpage?page=$prev'>previous</a>";
        }else{
            $paginate.= "<span class='disabled'>previous</span>";   }



        // Pages    
        if ($lastpage < 7 + ($stages * 2))  // Not enough pages to breaking it up
        {   
            for ($counter = 1; $counter <= $lastpage; $counter++)
            {
                if ($counter == $page){
                    $paginate.= "<span class='current'>$counter</span>";
                }else{
                    $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
            }
        }
        elseif($lastpage > 5 + ($stages * 2))   // Enough pages to hide a few?
        {
            // Beginning only hide later pages
            if($page < 1 + ($stages * 2))       
            {
                for ($counter = 1; $counter < 4 + ($stages * 2); $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
                $paginate.= "...";
                $paginate.= "<a href='$targetpage?page=$LastPagem1'>$LastPagem1</a>";
                $paginate.= "<a href='$targetpage?page=$lastpage'>$lastpage</a>";       
            }
            // Middle hide some front and some back
            elseif($lastpage - ($stages * 2) > $page && $page > ($stages * 2))
            {
                $paginate.= "<a href='$targetpage?page=1'>1</a>";
                $paginate.= "<a href='$targetpage?page=2'>2</a>";
                $paginate.= "...";
                for ($counter = $page - $stages; $counter <= $page + $stages; $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
                $paginate.= "...";
                $paginate.= "<a href='$targetpage?page=$LastPagem1'>$LastPagem1</a>";
                $paginate.= "<a href='$targetpage?page=$lastpage'>$lastpage</a>";       
            }
            // End only hide early pages
            else
            {
                $paginate.= "<a href='$targetpage?page=1'>1</a>";
                $paginate.= "<a href='$targetpage?page=2'>2</a>";
                $paginate.= "...";
                for ($counter = $lastpage - (2 + ($stages * 2)); $counter <= $lastpage; $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
            }
        }

                // Next
        if ($page < $counter - 1){ 
            $paginate.= "<a href='$targetpage?page=$next'>next</a>";
        }else{
            $paginate.= "<span class='disabled'>next</span>";
            }

        $paginate.= "</div>";       


}
 echo $total_pages.' Results';
 // pagination
 echo $paginate;


}//end function
函数分页($connection,$tableName){
//分页
$targetpage=”http://localhost/website/all_categories.php";    
$limit=4;//设置每页显示的行数
//数行
$sql=“选择COUNT(*)作为$tableName中的num”;
$total_pages=$connection->query($sql)或die(mysqli_error($connection));
$row=$total_pages->fetch_assoc();
$total_pages=$row['num'];
//如果没有页码,请将其设置为第一页
$stages=3;
$page=isset($\u GET['page'])?$\u GET['page']:0;
$start=空($page)?$start=0:$start=($page-1)*$limit;
//初始页码设置
如果($page==0){$page=1;}
$prev=$page-1;
$next=$page+1;
$lastpage=ceil($total_pages/$limit);
$LastPagem1=$lastpage-1;
$paginate='';
如果($lastpage>1)
{   
$paginate.=“”;
//先前的
如果($page>1){
$paginate.=“”;
}否则{
$paginate.=“上一个”}
//页数
if($lastpage<7+($stages*2))//没有足够的页面将其拆分
{   
对于($counter=1;$counter 5+($stages*2))//是否有足够的页面来隐藏一些?
{
//开始仅隐藏后面的页面
如果($page<1+($stages*2))
{
对于($counter=1;$counter<4+($stages*2);$counter++)
{
如果($counter==$page){
$paginate.=“$counter”;
}否则{
$paginate.='';}
}
$paginate.=“…”;
$paginate.=“”;
$paginate.=“”;
}
//中间隐藏一些正面和一些背面
elseif($lastpage-($stages*2)>$page&&$page>($stages*2))
{
$paginate.=“”;
$paginate.=“”;
$paginate.=“…”;

对于($counter=$page-$stages;$counteredit:您显然是在函数中定义了
$start
。如果它是在SQL语句之前定义的,那么它显然是可访问的。但是,我怀疑,如果您不传递它,
$start
$end
,那么分页函数将非常有用。您还可以使用以下语法定义默认值:

function paginate($connection, $tableName, $start=0, $end="ALL") {
原文如下

函数有自己的作用域;您应该向函数传递在其外部定义的变量:

function paginate($connection, $tableName, $start, $end) {
唯一的例外是superglobals
$GLOBALS
$\u GET
$\u POST
$\u COOKIE
$\u请求
$\u会话
$\u文件
$\u环境
$\u服务器

您还可以通过超级全局数组
$GLOBALS
或在函数实现的开头添加
global$var;
来访问任何函数外部定义的函数。但是,不鼓励您这样做,除非(可以说)应用程序范围的配置指令。

(注意-这不一定是问题所在,但…)

应该是

$start = empty($page) ? 0 : ($page - 1) * $limit;

您正在函数内设置
$start
$limit
,但您没有返回这些变量。函数内的变量有自己的局部变量,因此无法从函数外访问

您需要在函数外部输入所需的变量。由于您需要多个变量,因此可以在关联数组中返回这些变量。例如,如果将其作为函数的最后一行:

return array( 'start' => $start, 'limit' => $limit );
…您可以这样调用函数:

$result = paginate($connection, "categories");
$sql = 'SELECT * FROM categories ORDER BY cat_name LIMIT ' .
    $result['start'] . ', ' . $result['limit'];
…并使用如下结果:

$result = paginate($connection, "categories");
$sql = 'SELECT * FROM categories ORDER BY cat_name LIMIT ' .
    $result['start'] . ', ' . $result['limit'];

感谢您的注意!我立即更改了:)谢谢!您说服我只使用全局$var。它使一切变得更简单:)@赛博,我希望我没有。否则,当你有bug时,你会诅咒我,因为某些全局正在某个地方被更改,而你不知道在哪里。只需传递额外的参数。这就是为什么你不应该向初学者提及全局。哈哈!对不起,全局对我来说更有意义。迈克,我将使用你提供的代码。你的代码工作正常太好了!这在我的php项目中将非常方便:)谢谢!