1. Codeigniter Framework (CodeIgniter Framework Tutorial) Basic Tutorials of Codeigniter Framework
  2. কোডইগনাইটার ইনস্টল (CodeIgniter Install Tutorial in Bangla)
  3. How to create First Application in CodeIgniter
  4. কোডইগনাইটারের URL স্ট্রাকচার (structure of codeigniter)
  5. Codeigniter দিয়ে query করা এবং result দেখা (CI Query & Show Results)
  6. Database থেকে Data দেখা (CI Fetch Data from Database)
  7. Model তৈরী এবং কন্ট্রোলারে Access (Create Model & Access in Controller)
  8. Codeigniter দিয়ে ডেটাবেসে data ঢুকানো (CodeIgniter Insert Data to Database)
  9. Form দিয়ে ডেটাবেসের data সম্পাদনা (Data Edit in Database Via Form | Codeigniter Tutorials)
  10. ডেটাবেসের data delete (Data Delete in Database | Codeigniter Tutorials) | SP Foundationbd
  11. Form Validation টিউটোরিয়াল (CI Form Validation Tutorial | Codeigniter Tutorials) | SP Foundation
  12. Form validation tutorials (CI Form Validation Tutorial) - আরও উন্নত validation
  13. Codeigniter bootstrap integration এবং best প্রাকটিস | SP Foundationbd
  14. Codeigniter পেজিনেশন Tutorials (CodeIgniter Pagination Tutorial) | SP Foundationbd
  15. কোডইগনাইটার pagination tutorials (CodeIgniter Pagination Tutorial) - ২য় পদ্ধতিতে pagination
  16. Codeigniter সেশন Management (Session Management CodeIgniter) part one
  17. Codeigniter session ম্যানেজমেন্ট (Session Management CodeIgniter) - সেশন ড্রাইভার part two
  18. কোডইগনাইটার file আপলোড (CodeIgniter File Upload)
  19. কোডইগনাইটার Ajax টিউটোরিয়াল (CodeIgniter Ajax Tutorial) | SP Foundationbd
  20. কোডইগনাইটার URI রাউটিং টিউটোরিয়াল (CodeIgniter URI Routing Bangla Tutorials) | SP Foundationbd
  21. কোডইগনাইটারে একসাথে একাধিক ডেটাবেস ব্যবহার (Use Multiple Database Together in CodeIgniter)

Codeigniter পেজিনেশন Tutorials (CodeIgniter Pagination Tutorial) | SP Foundationbd

যখন কোন টেবিলে শত শত data থাকে তখন Pagination করা হয় কারন একসাথে সব row যদি একটা পেজে দেখাতে যান তাহলে লোড হতে অনেক সময় লাগবে তাছাড়া scroll করে দেখাও সমস্যা। কোডইগনাইটারে pagination করা খুব সহজ। কন্ট্রোলারে কয়েকটি configuration প্যারামিটার দিতে হয় এরপর ভিউ ফাইলে ১টা লাইন লিখলেই আপনার কাজ শেষ। বাকি সব কাজ কোডইগনাইটার একাই করবে।

 পেজিনেশন দুইভাবে করা যায়। প্রথমত URL এ কোয়েরি স্ট্রিং ছাড়া এবং দ্বিতীয়ত প্যারামিটার যেমন page number (কোয়েরি স্ট্রিং) ইত্যাদি ব্যবহার করে। ১ নম্বরটিই সহজ এবং বাই ডিফল্ট কনফিগারেশনে কোডইগনাইটার এভাবেই pagination তৈরী করে। আমরা  এই পেজে যে project টি দিয়েছি (CI এর) সেখানে ১ম পদ্ধতি ব্যবহার করে pagination করা আছে। তবে অনেক জায়গায় এটা কাজ করবেনা তখন ২য় পদ্ধতি ব্যবহার করতে হবে। এই টিউটোরিয়ালে দুটোই দেখাচ্ছি

 ১ম পদ্ধতি (query string ছাড়া)

"Users" কন্ট্রোলারেই সব pagination code আছে (index মেথডে)। controller টি খুলে রাখুন, এখানে আর code দেবনা শুধু ব্যাখ্যা দিচ্ছি।

সবার আগে pagination library টি load করতে নিচের মত

1.$this->load->library('pagination');

 Library load হয়ে গেছে। এবার পেজিনেশনের জন্য configuration ঠিক করতে হবে। নিচে দেখুন কিভাবে configuration দিয়েছি

01.$config['base_url'] = site_url('users/index');

02.$config['total_rows'] = $this->db->get('users')->num_rows();

03.$config['per_page'] = 5;

04.$config['num_links'] = 5;

05.$config['full_tag_open'] = '<ul class="pagination no-margin">';

06.$config['full_tag_close'] = '</ul>';

07.$config['cur_tag_open'] = '<li class="active"><a href="/">';

08.$config['cur_tag_close'] = '</a></li>';

09.$config['prev_tag_open'] = '<li>';

10.$config['prev_tag_close'] = '</li>';

11.$config['next_tag_open'] = '<li>';

12.$config['next_tag_close'] = '</li>';

13.$config['num_tag_open'] = '<li>';

14.$config['num_tag_close'] = '</li>';

15.$config['last_tag_open'] = '<li>';

16.$config['last_tag_close'] = '</li>';

17.$config['first_tag_open'] = '<li>';

18.$config['first_tag_close'] = '</li>';

19.$config['next_link'] = 'Next >';

20.$config['prev_link'] = '< Prev';

  1. 22.if($this->uri->segment(3)) {

23.$data['segment'] = $this->uri->segment(3);

24.} else {

25.$data['segment'] = 0;

26.}

27.$this->pagination->initialize($config);

 ব্যাখ্যা: $config['base_url'] এ URL দিতে হবে, যেটা হবে আসলে কোন্ কন্ট্রোলারের কোন‌ মেথডে pagination দেখতে চান সেটার URL, যেমন আমাদের এই এপ্লিকেশনে Users কন্ট্রোলারের index মেথডে pagination করছি তাই এখানে base_url হবে site_url('users/index')

 $config['total_rows'] এখানে একটা সংখ্যা দিতে হবে। এই সংখ্যা হবে সর্বমোট row এর সংখ্যা। যে টেবিলের data দেখানোর জন্য pagination করছেন সেটার row সংখ্যা। যেমন আমি দিয়েছি $this->db->get('users')->num_rows(). এটা "users" টেবিলের সব row সংখ্যা return করে। এই সংখ্যার উপর ভিত্তি করেই codeigniter pagination তৈরী করবে।

 এরপর $config['per_page'] এখানে প্রতি পেজে কতটি করে row বা ata দেখতে চান সেটার সংখ্যা দিতে হবে। যেমন আমি 5 দিয়েছি ফলে প্রতি পেজে ৫টি করে দেখিয়ে এরপর নিচে পেজিনেশনের link গুলি দেখাবে।

 এরপর আছে $config['num_links'] এখানেও একটি সংখ্যা দিতে হবে, এটা হল প্রতি পেজে কতটি করে লিংক দেখাবে সেটার সংখ্যা। 

 এরপরের গুলি গুরত্বপূর্ন configuration নয়। pagination section টি কোন এলিমেন্টের মধ্যে থাকবে, বর্তমান link কোন এলিমেন্টের মধ্যে থাকবে এসবের সেটিংস। এগুলি সহজ, নাম দেখেই বোঝা যাচ্ছে কোন $config কিসের জন্য ব্যবহৃত হয়েছে।

 যেহেতু URL থেকে data নিয়ে pagination হবে তাই CI কে বলে দিতে হবে যে URL এর কোন অংশকে সে পেজিনেশনের জন্য ব্যবহার করবে। এজন্য CI এর uri class ব্যবহার করা হয়

1.if ($this->uri->segment(3)) {

2.$data['segment'] = $this->uri->segment(3);

3.} else {

4.$data['segment'] = 0;

5.}

 $this->uri->segment(3) এটা দিয়ে URL এর ৩ নম্বর অংশকে বিবেচনা করা হয়েছে (৩ নং অংশ ধরবে)। অর্থ্যাৎ URL এ যদি ৩ নং অংশ থাকে তাহলে $data['segment'] এর মান ঐটাই হবে (কেননা ৩ নং অংশটি একটি সংখ্যা এবং এই সংখ্যাই CI তার কোয়েরির লিমিটে ব্যবহার করে) অন্যথায় মান হবে 0.

 

** http://localhost/ spfoundationbd /users/index/10 এখানে $this->uri->segment(3) এর মান হবে "10",  $this->uri->segment(2) এর মান হবে "index", ক্লিয়ার?? অর্থ্যাৎ যে অংশ ধরতে চান সেটার নাম্বার।

** এই $segment ভিউ ফাইলে ব্যবহার করে নাম্বারিং করেছি এবং লিমিটেও ব্যবহার করেছি। ভিউ ফাইলে দেখবেন $segment++ এভাবে আছে, মানে হল URL এ যে মান থাকবে সেটার সাথে ১ যোগ করে প্রথম row টির নাম্বারিং হবে। যদি ২ নম্বর পেজে থাকেন তাহলে $this->uri->segment(3) এর মান দেখাবে ৫ এবং এই ৫ এর সাথে ১ যোগ করে (২য় পেজে) প্রথম row এর নাম্বারিং হবে ৬, এভাবে ৩য় পেজের ১ম row এর নাম্বার হবে ১১  ...ইত্যাদি।

এরপর শেষে $this->pagination->initialize($config); এই লাইন দিয়ে পেজিনেশনের সব কনফিগারেশনগুলি সেট করা হয়েছে। এবার নিচে দেখুন কোয়েরি কিভাবে করেছি

1.$query = $this->db->limit($config['per_page'], $data['segment'])->order_by('id','desc')->get('users');

অতএব limit() এর ভিতর প্যারামিটারগুলি ডাইনামিকালি পরিবর্তন হবে। ১ম প্যারামিটার নিবে $config থেকে তথা কতটি করে দেখাবে সেটার সংখ্যা আর ২য় প্যারামিটারটি নিচ্ছে আসলে URL থেকে। URL পরিবর্তন হবে সাথে সাথে এই $data['segment'] এর মানও বদলাবে।

 পেজিনেশনের মুল কাজ কন্ট্রোলারেই শেষ এবার শুধু ভিউ ফাইলে যেখানে পেজিনেশন দেখতে চান সেখান ১টি লাইন যোগ করতে হবে, লাইনটি

1.$this->pagination->create_links();