v2.5.2
Giriş yap

Datatable Ajax Data Gönderme ?

aydinkeskin
667 defa görüntülendi

aşağıdaki gibi bir data gönderiyorum kategoriye göre sıralama yaptığm için

silik olan kısmı aynı data içerisinde bir türlü gönderemedim.
onu gönderemediğim içinde datatables içindekisayfada su kadar kayıt var
sayafalama işlemi de çalışmıyor haliyle.

 
			ajax: {
				url: r + 'blog-list-data.php',
				type: 'POST',
				// data: {  
					// pagination: {
						// perpage: 50,
					// },
				// },
				data: function(data){         
					var kategoriSec = $('#kategoriSira').val(); 
					data.kategoriSira = kategoriSec;
				},
			},
 

php tarafında da bu şekilde alıyorum.

$GelenDeger = $_POST['search']['value']; 
$kategoriSira = $_POST['kategoriSira'];
			
## Search 
$Sirala = " "; 
if($kategoriSira != ''){
    $Sirala .= " and (blog.katid='".$kategoriSira."') ";
}
if($GelenDeger != ''){
	$Sirala .= " and (blog.katid like '%".$GelenDeger."%'  ) ";
}
			
$kod = "SELECT
				blog.id as blogID,
				blog.durum as blogdurum,
				blog.baslik,
				blog.katid,
				blog.dilID,
				blog.sira,
				blog.spot,
				blog.icerik,
				blog.create_at as blogTarih,
				blog_kat.id as blogkatID,
				blog_kat.durum as blogkatdurum,
				blog_kat.adi FROM blog INNER JOIN blog_kat ON blog.katid = blog_kat.id
WHERE blog.dilID=? ".$Sirala." order by blogID DESC ";




...

....


		$json =  json_encode($ver);

$data = $alldata = json_decode( $json );


$datatable = array_merge(array('pagination' => array(), 'sort' => array(), 'query' => array()), $_REQUEST);

// search filter by keywords
$filter = isset($datatable['query']['generalSearch']) && is_string($datatable['query']['generalSearch']) ? $datatable['query']['generalSearch'] : '';
if (!empty($filter)) {
    $data = array_filter($data, function ($a) use ($filter) {
        return (boolean)preg_grep("/$filter/i", (array)$a);
    });
    unset($datatable['query']['generalSearch']);
}

// filter by field query
$query = isset($datatable['query']) && is_array($datatable['query']) ? $datatable['query'] : null;
if (is_array($query)) {
    $query = array_filter($query);
    foreach ($query as $key => $val) {
        $data = list_filter($data, array($key => $val));
    }
}

$sort = !empty($datatable['sort']['sort']) ? $datatable['sort']['sort'] : 'asc';
$field = !empty($datatable['sort']['field']) ? $datatable['sort']['field'] : 'id';

$meta = array();
$page = !empty($datatable['pagination']['page']) ? (int)$datatable['pagination']['page'] : 1;
$perpage = !empty($datatable['pagination']['perpage']) ? (int)$datatable['pagination']['perpage'] : -1;

$pages = 1;
$total = count($data); // total items in array

// sort
usort($data, function ($a, $b) use ($sort, $field) {
    if (!isset($a->$field) || !isset($b->$field)) {
        return false;
    }

    if ($sort === 'asc') {
        return $a->$field > $b->$field ? true : false;
    }

    return $a->$field < $b->$field ? true : false;
});

// $perpage 0; get all data
if ($perpage > 0) {
    $pages = ceil($total / $perpage); // calculate total pages
    $page = max($page, 1); // get 1 page when $_REQUEST['page'] <= 0
    $page = min($page, $pages); // get last page when $_REQUEST['page'] > $totalPages
    $offset = ($page - 1) * $perpage;
    if ($offset < 0) {
        $offset = 0;
    }

    $data = array_slice($data, $offset, $perpage, true);
}

$meta = array(
    'page' => $page,
    'pages' => $pages,
    'perpage' => $perpage,
    'total' => $total,
    'KatSira' => $kategoriSira,
);

// if selected all records enabled, provide all the ids
if (isset($datatable['requestIds']) && filter_var($datatable['requestIds'], FILTER_VALIDATE_BOOLEAN)) {
    $meta['rowIds'] = array_map(function ($row) {
        foreach ($row as $first) break;
        return $first;
    }, $alldata);
}


header('Content-Type: application/json');
header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Methods: GET, PUT, POST, DELETE, OPTIONS');
header('Access-Control-Allow-Headers: Content-Type, Content-Range, Content-Disposition, Content-Description');

$result = array(
    'meta' => $meta + array(
            'sort' => $sort,
            'field' => $field,
        ),
    'data' => $data
);

echo json_encode($result, JSON_PRETTY_PRINT);

hl böyle oluncada değer gönderemediğim için
Kayıt yok (NaN kayıt içerisinden bulunan)
bu şekilde çıkıyor.

Cevap yaz
Cevaplar (2)
aydinkeskin
1259 gün önce

kendim hallettim teşekkür ederim sorun server-side ile alakası listelemeye elle değer verdiğim için bu sorun oluyordu onuda hallettik sonra gördüm cevabını ilgin için teşekkür ederim tekrar.