使用JSON对象在Laravel中分页

使用JSON对象在Laravel中分页,laravel,datatables,client-side,Laravel,Datatables,Client Side,你好,我有一个xml格式的数据,我试着用JSON转换它。我想在拉雷维尔做一个分页。这里我给出了控制器中的代码。我的代码出现了错误 错误: PageController.php第189行中的FatalErrorException:调用成员 字符串上的函数paginate() 这是我的控制器: public function soap(Request $request){ $this->validate($request, [ 'nama' =

你好,我有一个xml格式的数据,我试着用JSON转换它。我想在拉雷维尔做一个分页。这里我给出了控制器中的代码。我的代码出现了错误

错误:

PageController.php第189行中的FatalErrorException:调用成员 字符串上的函数paginate()

这是我的控制器:

public function soap(Request $request){ 
            $this->validate($request, [
            'nama' => 'required',
            'negara' => 'required',
            'pencarian'=>'required'
            ]);

            $count = Pengaturan::where('key', 'visitor')        
            ->first();
            $array=array_map('intval', str_split($count->value));

            $kategori = $request->input("pencarian");
            $nama = $request->input("nama");
            $negara = $request->input("negara");
            $pages = $request->get("pageby");

            $soapClient = new SoapClient("http://interop.bnp2tki.go.id/perwakilanWS/wsdl"); 
            $param;     
            if($kategori=="2"){ //search by paspor
                $param = array( 
                'user_id'=>'kjri_jed', 
                'user_pass'=>'123',
                'paspor'=>$nama         
                );

                $error = 0; 
                try { 
                    $info = $soapClient->__call("ws_view_tkibypaspor", $param);         
                    if($info!="notfound"){                  
                        $informasi = preg_replace('/&(?!#?[a-z0-9]+;)/', '&', $info);
                        $xml = new SimpleXMLElement($informasi);
                        $data = $xml->tki_data;
                        $pagess = $xml->total_page;
                        $hasil = array($data);
                        $json = json_encode($hasil);
                        $paging = $json->paginate(10);

                        return view('page.search-tki', compact('data', 'array','paging'));
                        }else{
                        $data=$info;
                        return view('page.search-tki', compact('data', 'array'));                   
                    }
                    } catch (SoapFault $fault) { 
                    return view('page.search-tki', compact('data', 'array'));
                } 

                }else{ //by nama
                $param = array( 
                'user_id'=>'kjri_jed', 
                'user_pass'=>'123',
                'nama'=>$nama,
                'negara'=>$negara,
                'page'=>$pages          
                );
                $error = 0; 

                try { 
                    $info = $soapClient->__call("ws_view_tkibyname", $param); 
                    if($info!="notfound"){
                        $informasi = preg_replace('/&(?!#?[a-z0-9]+;)/', '&', $info);
                        $xml = new SimpleXMLElement($informasi);
                        $data = $xml->tki_data;
                        $pagess = $xml->total_page;

                        //merubah ke pagination
                        //$hasil = array($data);
                        $json = json_encode($data);
                        $paging = $json->paginate(10);

                        return view('page.search-tki', compact('data', 'array','pagess','nama','negara','kategori','json','paging'));
                        }else{
                        $data=$info;
                        return view('page.search-tki', compact('data', 'array'));                   
                    }
                    } catch (SoapFault $fault) { 
                    return view('page.search-tki', compact('data', 'array'));
                } 

            }       
        }
有人能帮我吗? 请参见:)

方法
paginate()
适用于
QueryBuilder::class
实例

您可以使用laravel
集合

$informasi = preg_replace('/&(?!#?[a-z0-9]+;)/', '&', $info);
$xml = new SimpleXMLElement($informasi);
$data = $xml->tki_data;
$pagess = $xml->total_page;
$hasil = array($data);
$page = collect($hasil)->take(10);
$paging = $page->toJson();
或者您可以使用
forPage($pageNumber,$pageCount)
方法

$informasi = preg_replace('/&(?!#?[a-z0-9]+;)/', '&', $info);
$xml = new SimpleXMLElement($informasi);
$data = $xml->tki_data;
$pagess = $xml->total_page;
$hasil = array($data);
$page = collect($hasil)->forPage(1,10);
$paging = $page->toJson();

感谢您回答我的问题,我将尝试您的回答:)我已经在控制器中编写了代码并压缩了它。我在视图中尝试了render()方法。我得到的错误是这样的:“81B2083A324452E74994EEB75563AC98B3752FB.php第59行中的FatalErrorException:调用字符串上的成员函数render()。那么如何在视图中使用它呢?方法
render()
应该做什么$分页是json格式的字符串。它应该在视图中显示分页