使用JSON对象在Laravel中分页
你好,我有一个xml格式的数据,我试着用JSON转换它。我想在拉雷维尔做一个分页。这里我给出了控制器中的代码。我的代码出现了错误 错误: PageController.php第189行中的FatalErrorException:调用成员 字符串上的函数paginate() 这是我的控制器:使用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' =
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格式的字符串。它应该在视图中显示分页