ประยุกต์ DataTable ร่วมกับ TCPDF ออกรายงาน ใน Codeigniter ตอนที่ 7

เขียนเมื่อ 6 ปีก่อน โดย Ninenik Narkdee
tcpdf codeigniter 3 ออกรายงาน datatable codeigniter

คำสั่ง การ กำหนด รูปแบบ ตัวอย่าง เทคนิค ลูกเล่น การประยุกต์ การใช้งาน เกี่ยวกับ tcpdf codeigniter 3 ออกรายงาน datatable codeigniter

ดูแล้ว 9,567 ครั้ง


ต่อเนื่องการประยุกต์เพิ่มเติม DataTable ใช้งานร่วมกับ TCPDF ออกรายงานเป็นไฟล์ PDF จากรายการข้อมูล
จำนวนมาก รองรับภาษาไทย 
    ต่อจากตอนที่แล้วเราได้รู้จักวิธีการประยุกต์การใช้งาน PHPExcel ออกรายการเป็นไฟล์ excel สำหรับข้อมูล
จำนวนมากๆ โดยทำงานในฝั่ง server side script 
    ประยุกต์ DataTable ร่วมกับ PHPExcel ออกรายงาน ใน Codeigniter ตอนที่ 6 
 
เนื้อหาในตอนนี้เรามาประยุกต์กันต่อ สำหรับการออกรายงาน
เป็น PDF ไฟล์ โดยตัว PDF library ที่เราจะใช้งานก็คือ TCPDF ซึ่งมีบทความ เกี่ยวกับการใช้งาน TCPDF ร่วมกับ
Codeigniter มาก่อนหน้าแล้ว เราจะใช้แนวทางต่อจากบทความนั้นมาใช้เพิ่มเติม หากยังไม่เคยใช้งานให้ทำตาม
บทความตามลิ้งค์ด้านล่างข้างต้นนี้ก่อน
    ประยุกต์การใช้งาน tcpdf สร้าง pdf ไฟล์ ใน codeigniter 
 
โดยในตัวอย่างที่จะแนะนำ จะใช้ font THSarabun.ttf และ THSarabun-Bold.ttf ในการกำหนดให้รองรับ
การแสดงผลภาษาไทย โดยวิธีการสร้าง fonts สำหรับใช้งานใน TCPDF มีแนะนำไว้ในลิ้งค์ด้านบน ในตอน
ท้ายของบทความ หลักจากเราได้ไฟล์ fonts ทั้ง 6 ไฟล์มาแล้ว เราก็ copy ไปวางในโฟลเดอร์
 
apps > third_party > tcpdf > fonts  
 
ตามรูปตัวอย่างด้านล่าง
 
 


 
 
ต่อไปให้เราดูในส่วนของไฟล์ Export.php ในโฟลเดอร์ apps > controllers 
เราจะใช้ไฟล์เดียวกันกับเนื้อหาตอนที่ผ่านมา ที่ใช้ในการส่งออกเป็นไฟล์ excel ด้วย PHPExcel
โดยจะปรับโค้ดใหม่เล็กน้อยในส่วนของฟังก์ชั่นการส่งไฟล์ excel โดยเปลี่ยนจากฟังก์ชั่น index()
เป็น excel() และเพิ่มฟังก์ชั่น pdf() เข้ามา ดังโค้ดด้านล่าง
 
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
  
class Export extends CI_Controller {

    public function __construct() {
        parent::__construct();
		$this->load->library('excel');    
		$this->load->library('Pdf');
    }
    public function excel() {
     
		// เรียนกใช้ PHPExcel  
		$objPHPExcel = new PHPExcel();   
		// เราสามารถเรียกใช้เป็น  $this->excel แทนก็ได้
		 
		// กำหนดค่าต่างๆ ของเอกสาร excel
		$objPHPExcel->getProperties()->setCreator("Ninenik.com")  
									 ->setLastModifiedBy("Ninenik.com")  
									 ->setTitle("PHPExcel Test Document")  
									 ->setSubject("PHPExcel Test Document")  
									 ->setDescription("Test document for PHPExcel, generated using PHP classes.")  
									 ->setKeywords("office PHPExcel php")  
									 ->setCategory("Test result file");      
	 
		// กำหนดชื่อให้กับ worksheet ที่ใช้งาน  
		$objPHPExcel->getActiveSheet()->setTitle('Provinces Report');  
		   
		// กำหนด worksheet ที่ต้องการให้เปิดมาแล้วแสดง ค่าจะเริ่มจาก 0 , 1 , 2 , ......  
		$objPHPExcel->setActiveSheetIndex(0);        
									  
		// การจัดรูปแบบของ cell  
		$objPHPExcel->getDefaultStyle()  
								->getAlignment()  
								->setVertical(PHPExcel_Style_Alignment::VERTICAL_TOP)  
								->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);   
								//HORIZONTAL_CENTER //VERTICAL_CENTER               
								 
		// จัดความกว้างของคอลัมน์
		$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20);
		$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(20);
		$objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(20);     
		$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(20);                                              
		 
		// กำหนดหัวข้อให้กับแถวแรก
		$objPHPExcel->setActiveSheetIndex(0)  
					->setCellValue('A1', '#')    
					->setCellValue('B1', 'province id')  
					->setCellValue('C1', 'province name')  
					->setCellValue('D1', 'province name eng');    
			 
		// ดึงข้อมูลเริ่มเพิ่มแถวที่ 2 ของ excel            
		$start_row=2;  
		
		// กรณีส่งตัวแปร GET['all'] หรือให้แสดงข้อมูลทั้งหมด
		if($this->input->get('all')){
			$sql = $this->session->ses_sql_str_all; // ใช้คำสั่ง SQL ที่ดึงรายกรทั้งหมด
		}else{
	 		$sql = $this->session->ses_sql_str; // ใช้คำสั่ง SQL ที่ดึงข้อมูลเฉพาะหน้านั้นๆ
		}
		$query = $this->db->query($sql);  
		$result = $query->result_array(); 
		$i_num=0;
		if(count($result)>0){
			foreach($result as $row){
				$i_num++;
				 
				// หากอยากจัดข้อมูลราคาให้ชิดขวา
				$objPHPExcel->getActiveSheet()
					->getStyle('C'.$start_row)
					->getAlignment()  
					->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);         
					 
				// หากอยากจัดให้รหัสสินค้ามีเลย 0 ด้านหน้า และแสดง 3     หลักเช่น 001 002
				$objPHPExcel->getActiveSheet()
					->getStyle('B'.$start_row)
					->getNumberFormat()
					->setFormatCode('000');          
				 
				// เพิ่มข้อมูลลงแต่ละเซลล์                          
				$objPHPExcel->setActiveSheetIndex(0)  
							->setCellValue('A'.$start_row, $i_num)  
							->setCellValue('B'.$start_row, $row['province_id'])  
							->setCellValue('C'.$start_row, $row['province_name'])  
							->setCellValue('D'.$start_row, $row['province_name_eng']);           
				 
				// เพิ่มแถวข้อมูล
				$start_row++;               
			}
	 
			// กำหนดรูปแบบของไฟล์ที่ต้องการเขียนว่าเป็นไฟล์ excel แบบไหน ในที่นี้เป้นนามสกุล xlsx  ใช้คำว่า Excel2007
			// แต่หากต้องการกำหนดเป็นไฟล์ xls ใช้กับโปรแกรม excel รุ่นเก่าๆ ได้ ให้กำหนดเป็น  Excel5
			$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');  // Excel2007 (xlsx) หรือ Excel5 (xls)        
			 
			$filename='Province-'.date("dmYHi").'.xlsx'; //  กำหนดชือ่ไฟล์ นามสกุล xls หรือ xlsx
			// บังคับให้ทำการดาวน์ดหลดไฟล์
			// https://www.freeformatter.com/mime-types-list.html
			// header('Content-Type: application/vnd.ms-excel'); //mime type xls
			header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); //mime type	 xlsx	
			header('Content-Disposition: attachment;filename="'.$filename.'"'); //tell browser what's the file name
			header('Cache-Control: max-age=0'); //no cache
			ob_end_clean();     
			$objWriter->save('php://output'); // ดาวน์โหลดไฟล์รายงาน
			// หากต้องการบันทึกเป็นไฟล์ไว้ใน server  ใช้คำสั่งนี้ $this->excel->save("/path/".$filename); 
			// แล้วตัด header ดัานบนทั้ง 3 อันออก   
			exit();    
		}
    }
	public function pdf() {

		// เริ่มสร้างไฟล์ pdf
		$pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);
		 
		// กำหนดรายละเอียดของไฟล์ pdf
		$pdf->SetCreator(PDF_CREATOR);
		$pdf->SetAuthor('ninenik');
		$pdf->SetTitle('TCPDF table report');
		$pdf->SetSubject('TCPDF ทดสอบ');
		$pdf->SetKeywords('TCPDF, PDF, ทดสอบ,ninenik, guide');
		 
		// กำหนดข้อความส่วนแสดง header
		$pdf->SetHeaderData(
			PDF_HEADER_LOGO, // โลโก้ กำหนดค่าในไฟล์  tcpdf_config.php 
			PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.' 001',
			PDF_HEADER_STRING, // กำหนดเพิ่มเติมในไฟล์  tcpdf_config.php 
			array(0,0,0),  // กำหนดสีของข้อความใน header rgb 
			array(0,0,0)   // กำหนดสีของเส้นคั่นใน header rgb 
		);
		 
		$pdf->setFooterData(
			array(0,64,0),  // กำหนดสีของข้อความใน footer rgb 
			array(0,0,0)   // กำหนดสีของเส้นคั่นใน footer rgb 
		);
		 
		// กำหนดฟอนท์ของ header และ footer  กำหนดเพิ่มเติมในไฟล์  tcpdf_config.php 
		$pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
		$pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
		 
		// ำหนดฟอนท์ของ monospaced  กำหนดเพิ่มเติมในไฟล์  tcpdf_config.php 
		$pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
		 
		// กำหนดขอบเขตความห่างจากขอบ  กำหนดเพิ่มเติมในไฟล์  tcpdf_config.php 
		$pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
		$pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
		$pdf->SetFooterMargin(PDF_MARGIN_FOOTER);
		 
		$pdf->setPrintHeader(false); // ไม่แสดงส่วนของ header
		$pdf->setPrintFooter(false);  // ไม่แสดงส่วนของ footer
		 
		// กำหนดแบ่่งหน้าอัตโนมัติ
		$pdf->SetAutoPageBreak(FALSE, PDF_MARGIN_BOTTOM); // กำหนดเป็น FALSE
		 
		// กำหนดสัดส่วนของรูปภาพ  กำหนดเพิ่มเติมในไฟล์  tcpdf_config.php 
		$pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);
		 
		// อนุญาตให้สามารถกำหนดรุปแบบ ฟอนท์ย่อยเพิมเติมในหน้าใช้งานได้
		$pdf->setFontSubsetting(true);
		 
		// กำหนด ฟอนท์
		$pdf->SetFont('thsarabunpsk', '', 18, '', true);
		 
		// เพิ่มหน้า 
		$pdf->AddPage();
 
 		$tbl_style = '
			<style>
			.tableHeader{
				background-color:#2d4154;
				color:#FFFFFF;	
				font-size:18px;
				font-weight:bold;
			}
			.tableBodyEven{
				background-color:#FFFFFF;
				font-size:18px;
			}
			.tableBodyOdd{
				background-color:#F3F3F3;
				font-size:18px;
			}
			</style>
		';
		// 630  
 		$tbl_header = '<table border="0" align="center" cellpadding="2" cellspacing="0">';
		$tbl_thead = '
		<tr class="tableHeader">
			<th align="center" width="50">#</th>
			<th align="center" width="100">Province ID</th>
			<th align="center" width="240">Province Name</th>
			<th align="center" width="240">Province Name Eng</th>
		</tr>	
		';
		$page_break = 30; // กำหนดจำนวนรายการที่ต้องการแสดงในแต่ละหน้า
		$tbl_footer = '</table>';
		$tbl_body = '';
		// กรณีส่งตัวแปร GET['all'] หรือให้แสดงข้อมูลทั้งหมด
		if($this->input->get('all')){
			$sql = $this->session->ses_sql_str_all; // ใช้คำสั่ง SQL ที่ดึงรายกรทั้งหมด
		}else{
	 		$sql = $this->session->ses_sql_str; // ใช้คำสั่ง SQL ที่ดึงข้อมูลเฉพาะหน้านั้นๆ
		}
		$query = $this->db->query($sql);  
		$result = $query->result_array(); 
		$i_num=0;
		if(count($result)>0){
			foreach($result as $row){
				if($i_num%$page_break==0 && $i_num!=0){		
					$html = $tbl_style.$tbl_header.$tbl_thead.$tbl_body.$tbl_footer;		
					$pdf->writeHTMLCell(0, 0, '', '', $html, 0, 1, 0, true, '', true);
					$pdf->AddPage();
					$html = '';
					$tbl_body = '';
				}				
				$i_num++;
				$classTr = ($i_num%2==1)?"tableBodyOdd":"tableBodyEven";
				$tbl_body .= '
				<tr class="'.$classTr.'">
					<td align="center">'.$i_num.'</td>
					<td align="center">'.$row['province_id'].'</td>
					<td align="left">'.$row['province_name'].'</td>
					<td align="left">'.$row['province_name_eng'].'</td>
				</tr>					
				';
			}
		}
		// กำหนดเนื้อหาข้อมูลที่จะสร้าง pdf ในที่นี้เราจะกำหนดเป็นแบบ html โปรดระวัง EOD; โค้ดสุดท้ายต้องชิดซ้ายไม่เว้นวรรค
		$html = $tbl_style.$tbl_header.$tbl_thead.$tbl_body.$tbl_footer;
	 
		// สร้างข้อเนื้อหา pdf ด้วยคำสั่ง writeHTMLCell()
		$pdf->writeHTMLCell(0, 0, '', '', $html, 0, 1, 0, true, '', true);
	 
		// จบการทำงานและแสดงไฟล์ pdf
		// การกำหนดในส่วนนี้ สามารถปรับรูปแบบต่างๆ ได้ เช่นให้บันทึกเป้นไฟล์ หรือให้แสดง pdf เลย ดูวิธีใช้งานที่คู่มือของ tcpdf เพิ่มเติม
		$pdf->Output('example_'.date("dmYHi").'.pdf', 'D'); // (I - Inline แสดงทันที, D - Download, F - File บันทึก)
		
	}
}
 
 
หลักจะขออธิบายเฉพาะในส่วนของโค้ดที่ highlight ไว้ โดยในเฉพาะในส่วนของฟังก์ชั่น pdf() ส่วนฟังก์ชั่น
excel() นั้น โดยกล่าวไปแล้วในตอนที่ผ่านมา
 
$this->load->library('excel');    
$this->load->library('Pdf');
 
ทำการโหลด library ทั้ง PHPExcel และ TCPDF มาใช้งาน ตามบรรทัดที่ 8 และ 9
จากนั้นก็ตัดมาในส่วนของฟังก์ชั่น pdf() ข้ามมาที่บรรทัดที่ 160 เป็นการกำหนดชื่อ font ที่เราจะใช้งาน
ในที่นี้เราใช้ชื่อ font ที่เราไปทำการสร้างมา ชื่อว่า thsarabunpsk เป็นตัวแบบปกติ ขนาด 18
 
$pdf->SetFont('thsarabunpsk', '', 18, '', true);
 
ส่วนการจัดรูปแบบส่วนอื่นๆ ดูเพิ่มเติมได้ที่บทความ
    แนวทางจัดรูปแบบ header และ footer ของ pdf ไฟล์ที่สร้างด้วย tcpdf 
    จัดรูปแบบ header และ footer ของ pdf แบบกำหนดเองใน tcpdf 
 
ในเนื้อหานี้เราจะเน้นไปที่ตัวข้อมูลในตาราง dataTable
 
ต่อมาบรรทัดที่ 165-182 จะเป็นการจัดรูปแบบ css style ให้กับตารางที่เราต้องการแสดงเป็น PDF
โดยเก็บไว้ในตัวแปร $tbl_style
 
$tbl_style = '
    <style>
    .tableHeader{
        background-color:#2d4154;
        color:#FFFFFF;	
        font-size:18px;
        font-weight:bold;
    }
    .tableBodyEven{
        background-color:#FFFFFF;
        font-size:18px;
    }
    .tableBodyOdd{
        background-color:#F3F3F3;
        font-size:18px;
    }
    </style>
';
 
จะเป็นการกำหนด css class ให้กับ ส่วนที่ คอลัมน์หัวข้อ และแถวข้อมูลแถวเลขคี่และแถวข้อมูลเลขคู่
เราสามารถประยุกต์กำหนด style อื่นๆ เพิ่มเติมได้ แต่บางรูปแบบอาจจะไม่มีผลต่อไฟล์ PDF ที่ถูกสร้าง
จุดนี้ต้องลองใช้ดู
 
บรรทัดที่ 184 เป็นการกำหนดส่วนของ table ใว้ในตัวแปร $tbl_header 
 
$tbl_header = '<table border="0" align="center" cellpadding="2" cellspacing="0">';
 
โดยค่าหลักๆ ที่จะมีผลก็คือ ระยะห่างของแต่ละช่องของตารางกับขอบของช่องนั้น ที่กำหนดด้วย
cellpadding ในตัวอย่างเราจะใช้เท่ากับ 2  ค่าตรงนี้จะมีผลต่อการยืด การขยายของตาราง 
อีกจุดหนึ่งคือ เราไม่สามารถกำหนดให้ใช้งาน style css กำหนดความกว้างของตารางแบบเต็มหน้า
กระดาษแบบอัตโนมัติได้ (ไม่รวมขอบซ้ายขวา) หรือไม่สามารถกำหนดค่า width ให้กับ <table> ได้
แต่เราสามารถกำหนดขนาดเทียบได้ โดยที่ได้ทดสอบ กระดาษ A4 จะมีความกว้างที่ 210 มม. 
ค่าเริ่มต้นของ TCPDF ที่กำหนดในไฟล์
apps > third_party > tcpdf > config > tcpdf_config.php
กำหนดให้ระยะห่างจากขอบซ้ายและขวาข้างละ 15 มม. (ค่าเริ่มต้นของขนาดต่างๆ จะมีหน่วยเป็น มม. ยกเว้น font
มีหน่วยเป็น point (pt) )
ดังนั้น พื้นส่วนตรงกลางก็จะเหลือ 210 - 30 เท่ากับ 180 มม. คิดเป็นประมาณ  680 ในหน่วน px
แต่จากการทดสอบ ค่าความกว้างแบบเต็มในหน่วย px จะเหลือประมาณ 630 px หรือค่าลบไป 50 px 
เราจึงจะใช้ค่าที่ 630 px เป็นตัวหลักในการเทียบเคียงสำหรับกำหนดความกว้างของหัวข้อในตาราง
ซึ่งถ้าเราจะใช้หน่วย % ในการกำหนดความกว้าง ให้คิดเทียบจากค่า 630  แทน
 
ตามที่กล่าวไปแล้วข้างต้น บรรทัดที่ 185 - 192 เรามีการกำหนดความกว้างของหัวข้อของข้อมูล โดยหัวข้อ
ของข้อมูลนี้ จะแสดงทุกหน้าที่ขึ้นหน้าใหม่ ความกว้างของหัวข้อจะมีผลต่อความกว้างของตาราง 
 
$tbl_thead = '
<tr class="tableHeader">
    <th align="center" width="50">#</th>
    <th align="center" width="100">Province ID</th>
    <th align="center" width="240">Province Name</th>
    <th align="center" width="240">Province Name Eng</th>
</tr>	
';
 
ในแท็ก html เรากำหนดความกว้างเป็น px ดังนั้นขนาดของทั้ง 4 คอลัมน์จะต้องรวมกันเท่ากับ 630
หรือถ้าเราแปลงเป็น % แทน ก็จะใช้ค่า (50*100)/630 = 8% โดยประมาณ ใช้ทั้งหมด ก็จะได้เป็น
 
$tbl_thead = '
<tr class="tableHeader">
    <th align="center" width="8%">#</th>
    <th align="center" width="16%">Province ID</th>
    <th align="center" width="38%">Province Name</th>
    <th align="center" width="38%">Province Name Eng</th>
</tr>	
';
 
ต่อไปบรรทัดที่ 193 เป็นการกำหนดว่ารายการข้อมูลในแต่ละหน้า ให้แสดงครั้งละกี่รายการ แล้วตัดขึ้น
หน้าใหม่ 
 
$page_break = 30; // กำหนดจำนวนรายการที่ต้องการแสดงในแต่ละหน้า
 
ค่าจำนวนข้อมูล ให้เรากำหนดค่าตามต้องการ ให้สัมพันธ์กับการยืด ขยายของตาราง หากมีการปรับ css
ส่วนอื่นๆ
 
บรรทัดที่ 207 - 213 เป็นการกำหนดเงื่อนไขเพื่อขึ้นหน้าใหม่ และสร้างหัวข้อตารางทุกๆ ครั้งที่ขึ้นหน้า
ใหม่
 
if($i_num%$page_break==0 && $i_num!=0){		
    $html = $tbl_style.$tbl_header.$tbl_thead.$tbl_body.$tbl_footer;		
    $pdf->writeHTMLCell(0, 0, '', '', $html, 0, 1, 0, true, '', true);
    $pdf->AddPage();
    $html = '';
    $tbl_body = '';
}
 
บรรทัดที่ 216 - 223 จะเป็นในส่วนของข้อมูลที่เราจะนำมาแสดง ปรับจำนวนคอลัมน์ ฟิลด์ข้อมูลตาม
ที่ใช้งาน
 
$tbl_body .= '
<tr class="'.$classTr.'">
    <td align="center">'.$i_num.'</td>
    <td align="center">'.$row['province_id'].'</td>
    <td align="left">'.$row['province_name'].'</td>
    <td align="left">'.$row['province_name_eng'].'</td>
</tr>					
';
 
เบื้องต้นเป็นการอธิบายคร่าวๆ ส่วนของการสร้าง PDF ไฟล์ 
 
 
ต่อไปก็เป็นส่วนสุดท้ายของการใช้นำไปใช้งานร่วมกับ DataTable เราจะทำเช่นเดียวกับการประยุกต์
การใช้งานกรณีส่งออกเป็นไฟล์ excel รายละเอียดแสดงในโค้ด
 
<link rel="stylesheet" href="//cdn.datatables.net/1.10.15/css/jquery.dataTables.min.css">  
<link rel="stylesheet" href="//cdn.datatables.net/buttons/1.4.1/css/buttons.dataTables.min.css">
<script src="//cdn.datatables.net/1.10.15/js/jquery.dataTables.min.js"></script>
<script src="//cdn.datatables.net/buttons/1.4.1/js/dataTables.buttons.min.js"></script>
<script src="//cdn.datatables.net/buttons/1.4.1/js/buttons.print.min.js"></script>
 
<table id="table_server_id" class="display">
    <thead>
        <tr>
            <th>#</th>
            <th>Province ID</th>
            <th>Province Name TH</th>
            <th>Province Name ENG</th>
        </tr>
    </thead>
</table>
   
<script type="text/javascript">
// สร้างปุ่มแบบกำหนดเองให้กับ DataTable ในที่นี้ใช้ชื่อว่า exportExcel
$.fn.dataTable.ext.buttons.exportExcel = {
    className: 'buttons-excel',  // กำหนด css class 
    action: function ( e, dt, node, config ) { // กำหนดการทำงาน
		if(this.text() == 'Excel All Page'){ // ถ้าปุ่มที่กด มีข้อความว่า  Excel All Page
			window.open('<?=base_url('export/excel?all=1')?>'); // ให้เปิดไฟล์ export.php?all=1 เรียกฟังก์ชั่น excel ดึงข้อมูลทั้งหมด
		}else{
        	window.open('<?=base_url('export/excel')?>'); // ให้เปิดไฟล์ export.php เรียกฟังก์ชั่น excel ดึงข้อมูลเฉพาะหน้าปัจจุบัน
		}
    }
};
// สร้างปุ่มแบบกำหนดเองให้กับ DataTable ในที่นี้ใช้ชื่อว่า exportPdf
$.fn.dataTable.ext.buttons.exportPdf = {
    className: 'buttons-pdf',  // กำหนด css class 
    action: function ( e, dt, node, config ) { // กำหนดการทำงาน
		if(this.text() == 'PDF All Page'){ // ถ้าปุ่มที่กด มีข้อความว่า  PDF All Page
			window.open('<?=base_url('export/pdf?all=1')?>'); // ให้เปิดไฟล์ export.php?all=1  เรียกฟังก์ชั่น pdf ดึงข้อมูลทั้งหมด
		}else{
        	window.open('<?=base_url('export/pdf')?>'); // ให้เปิดไฟล์ export.php เรียกฟังก์ชั่น pdf ดึงข้อมูลเฉพาะหน้าปัจจุบัน
		}
    }
};
$(function(){
     $('#table_server_id').DataTable( {
        "processing": true, // แสดงข้อความกำลังดำเนินการ กรณีข้อมูลมีมากๆ จะสังเกตเห็นง่าย
        "serverSide": true,  // ใช้งานในโหมด Server-side processing
        "order": [], // กำหนดให้ไม่ต้องการส่งการเรียงข้อมูลค่าเริ่มต้น จะใช้ค่าเริ่มต้นตามค่าที่กำหนดในไฟล์ php
        "ajax": {
            "url": "<?=base_url("ajaxdata")?>", // ไฟล์ Server script php
            "data":{   // เพิ่มตัวแปรที่ต้องกาส่งเข้าไปแบบกำหนดเอง
                "page":function(){ // ใข้ข้อมูลตัวแปรชื่อ page
                    var dataTable1 = $('#table_server_id').DataTable(); // จะใช้ข้อมูลอ้างอิงจาก dataTable
                    return dataTable1.page.info().page; // ส่งค่าเลขหน้าปัจจุบันไปไว้ในตัวแปร page ค่าเรี่มต้นนับจาก 0
                }
            },
            "type": "POST"  // ส่งข้อมูลแบบ post
        },
        "columnDefs": [  // กำหนดลักษณะพิเสษเฉพาะสำหรับคอลัมน์ตารางที่ต้องการ
            { 
                "targets": [ 0 ], // เราต้องการกำหนดคอลัมน์แรก ค่าเริ่มต้นที่ 0
                "orderable": false, // ให้ไม่ต้องสามารถเรียงข้อมูลได้ เพราะเป็นลำดับรายการเฉยๆ 
            }
        ],
        "lengthMenu": [ 10, 25, 50, 100 ],		
		"dom": 'Bfrtip',
		"buttons":[
			{ // เริ่มต้นกลุ่มปุ่มแรก
				"extend":'collection',
				"text":'Export',
				"autoClose": true, // ให้ปิดกลุ่มปุ่มที่เปิดไว้แล้วอัตโนมัติ
				"buttons": [ // ปุ่มทั้งหมดในกลุ่ม export
					{ // ปุ่มส่งออก Excel ปุ่มแรก
						"extend": 'exportExcel', // สืบทอดจากปุ่มที่เรากำหนด
						"text": 'Excel current Page' // กำหนดข้อความปุ่มตามต้องการ
					},
					{ // ปุ่มส่งออก Excel ปุ่มที่สอง
						"extend": 'exportExcel',
						"text": 'Excel All Page'						
					},
					{ // ปุ่มส่งออก PDF ปุ่มแรก
						"extend": 'exportPdf', // สืบทอดจากปุ่มที่เรากำหนด
						"text": 'PDF current Page' // กำหนดข้อความปุ่มตามต้องการ
					},
					{ // ปุ่มส่งออก PDF ปุ่มที่สอง
						"extend": 'exportPdf',
						"text": 'PDF All Page'						
					},					
					'print'
				]							
			}, // จบส่วนของ กลุ่มปุ่มแรก
			'pageLength'
		]
    } );
});
</script>
 
ดูส่วนที่ปรับเพิ่มเติมในบรรทัดที่ทำการ highlight ไว้ 
เรามาลองทดสอบดูผลลัพธ์กัน เริ่มต้น ดูการแสดงของปุ่มที่เราสร้าง เมื่อเราคลิกที่ปุ่ม Export ปุ่มหลักแรก
ก็จะขึ้นปุ่มย่อย มีปุ่ม 
  1. Excel current Page
  2. Excel All Page
  3. PDF current Page
  4. PDF All Page
อยู่ด้วยดังรูป 

 


 
 
ทดสอบกดปุ่ม PDF current Page จะเป็นการแสดงรายการหน้าปัจจุบัน ที่แสดงแค่ 10 รายการ
การกดปุ่ม Export จะเป็นเปิดหน้าต่างใหม่เพื่อดาวน์โหดลไฟล์แบบ popup ดังนั้นถ้าบราเซอร์เรามีการบล็อก
การเปิด popup เป็นค่าเริ่มต้นไว้ ให้เราอนุญาตให้สามารถเปิด popup ก่อน ผลลัพธ์ไฟล์ PDF ที่ได้จะเป็นดังรูป
 
 


 
 
สุดท้ายทดสอบกดปุ่ม PDF All Page จะเป็นการแสดงรายการทั้งหมดในไฟล์ PDF ดังรูป 
โดยในรูปจะเห็นว่า ทุกครั้งที่มีการขึ้นหน้าใหม่ ก็จะมีการแสดงหัวข้อของข้อมูลกำกับในทุกๆ หน้า
มีการแสดงข้อมูลหน้าละ 30 รายการทุกหน้า และรายการข้อมูลก็ยังแสดงได้ต่อเนื่องด้วย
(ในรูปจะเห็นแค่บางส่วน)
 
 

 
 


 
 
เท่านี้เราก็สามารถส่งออกเอกสารไฟล์ PDF จากข้อมูลที่มีจำนวนมากๆ รองรับเงื่อนไขการเรียงข้อมูล การค้นหา
ที่สอดคล้องกับ DataTable ได้อย่างง่ายแล้ว ส่วนการจัดรูปแบบของข้อมูลใน PDF สามารถหาอ่านเพิ่มเติมเกี่ยว
กับ TCPDF ได้ 
 


กด Like หรือ Share เป็นกำลังใจ ให้มีบทความใหม่ๆ เรื่อยๆ น่ะครับ







เนื้อหาที่เกี่ยวข้อง









URL สำหรับอ้างอิง





คำแนะนำ และการใช้งาน

สมาชิก กรุณา ล็อกอินเข้าระบบ เพื่อตั้งคำถามใหม่ หรือ ตอบคำถาม สมาชิกใหม่ สมัครสมาชิกได้ที่ สมัครสมาชิก


  • ถาม-ตอบ กรุณา ล็อกอินเข้าระบบ
  • เปลี่ยน


    ( หรือ เข้าใช้งานผ่าน Social Login )







เว็บไซต์ของเราให้บริการเนื้อหาบทความสำหรับนักพัฒนา โดยพึ่งพารายได้เล็กน้อยจากการแสดงโฆษณา โปรดสนับสนุนเว็บไซต์ของเราด้วยการปิดการใช้งานตัวปิดกั้นโฆษณา (Disable Ads Blocker) ขอบคุณครับ