<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>select2 Archives - Mr Agus</title>
	<atom:link href="https://mragus.com/tag/select2/feed/" rel="self" type="application/rss+xml" />
	<link>https://mragus.com/tag/select2/</link>
	<description>Read, Learn and Share Ilmu yang Bermanfaat</description>
	<lastBuildDate>Sun, 27 Aug 2017 11:08:06 +0000</lastBuildDate>
	<language>en-US</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.2.2</generator>

<image>
	<url>https://mragus.com/wp-content/uploads/2017/07/Fav-icon-untuk-mragus.com_-150x150.png</url>
	<title>select2 Archives - Mr Agus</title>
	<link>https://mragus.com/tag/select2/</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>Membuat Dropdown Select2 dengan Request Ajax dan Php</title>
		<link>https://mragus.com/membuat-dropdown-select2-dengan-request-ajax-dan-php/</link>
					<comments>https://mragus.com/membuat-dropdown-select2-dengan-request-ajax-dan-php/#comments</comments>
		
		<dc:creator><![CDATA[Agus Wiji Suhariono]]></dc:creator>
		<pubDate>Thu, 03 Aug 2017 08:39:32 +0000</pubDate>
				<category><![CDATA[Php]]></category>
		<category><![CDATA[ajax]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[select2]]></category>
		<guid isPermaLink="false">https://mragus.com/?p=2730</guid>

					<description><![CDATA[<p>Assalamualaikum wr wb, pada kesempatan kali ini saya akan memberikan pembahasan mengenai cara membuat dropdown select2 dengan request ajax dan php. Select2 merupakan salah satu plugin yang banyak digunakan pada form, sebagai pengganti dropdown select di aplikasi web. Select2&#46;&#46;&#46;</p>
<p>The post <a rel="nofollow" href="https://mragus.com/membuat-dropdown-select2-dengan-request-ajax-dan-php/">Membuat Dropdown Select2 dengan Request Ajax dan Php</a> appeared first on <a rel="nofollow" href="https://mragus.com">Mr Agus</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>Assalamualaikum wr wb, pada kesempatan kali ini saya akan memberikan pembahasan mengenai cara membuat dropdown select2 dengan request ajax dan php. Select2 merupakan salah satu plugin yang banyak digunakan pada form, sebagai pengganti dropdown select di aplikasi web. Select2 memberikan kemudahan kepada user, karena <span id="more-2730"></span>kita bisa memilih data dengan memasukkan pencarian pada dropdown tersebut. Fitur ini sangatlah membantu karena kita tidak perlu menscroll dan memilih data ketika sumber data jumlah nya cukup banyak.</p>
<p>Sesuai dari judul artikel ini, kenapa menggunakan request ajax. Secara normal kita bisa mendefinisikan terlebih dahulu sumber data yang akan dipasangkan pada select2 tersebut, untuk jumlah data yang sedikit tidak masalah. Tetapi bagaimana jika data yang akan dipasang berjumlah ribuan, atau puluhan ribu. Hal ini tentu akan membuat load halaman pada lokasi di select2 tersebut akan sangat berat. Jika kita menggunakan ajax, client akan mengirimkan sebuah request pada fungsi yang digunakan untuk memanggil sumber data disaat user melakukan pencarian di select2 tersebut. Hal ini tentunya akan membuat halaman yang di load  dan menjadi lebih ringan.</p>
<h2></h2>
<div id="attachment_2736" style="width: 530px" class="wp-caption aligncenter"><img aria-describedby="caption-attachment-2736" decoding="async" class="wp-image-2736" src="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_138.png" alt="Membuat Dropdown Select2 dengan Request Ajax dan Php" width="520" height="220" srcset="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_138.png 1865w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_138-300x127.png 300w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_138-768x325.png 768w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_138-1024x433.png 1024w" sizes="(max-width: 520px) 100vw, 520px" /><p id="caption-attachment-2736" class="wp-caption-text">Membuat Dropdown Select2 dengan Request Ajax dan Php</p></div>
<h2>Membuat Dropdown Select2 dengan Request Ajax dan Php</h2>
<p>Langsung saja kita mulai untuk pengkodingannya, pertama tama kita download terlebih dahulu plugin select2 dari website resminya <a href="https://select2.github.io/">disini</a>. Select2 yang saya gunakan adalah versi 4.0.3. Pasangkan javascript dan css pada layouts aplikasi kita.</p>
<div id="attachment_2737" style="width: 534px" class="wp-caption aligncenter"><img aria-describedby="caption-attachment-2737" decoding="async" loading="lazy" class="wp-image-2737" src="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_142.png" alt="Membuat Dropdown Select2 dengan Request Ajax dan Php" width="524" height="47" srcset="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_142.png 1223w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_142-300x27.png 300w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_142-768x68.png 768w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_142-1024x91.png 1024w" sizes="(max-width: 524px) 100vw, 524px" /><p id="caption-attachment-2737" class="wp-caption-text">Memasang javascript Select2 pada layout</p></div>
<div id="attachment_2738" style="width: 531px" class="wp-caption aligncenter"><img aria-describedby="caption-attachment-2738" decoding="async" loading="lazy" class="wp-image-2738" src="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_141.png" alt="Membuat Dropdown Select2 dengan Request Ajax dan Php" width="521" height="77" srcset="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_141.png 1239w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_141-300x44.png 300w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_141-768x113.png 768w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_141-1024x150.png 1024w" sizes="(max-width: 521px) 100vw, 521px" /><p id="caption-attachment-2738" class="wp-caption-text">Memasang css select2 pada layout</p></div>
<p>Struktur tabel yang saya gunakan <strong>tb_propinisi</strong>.</p>
<pre class="lang:default decode:true EnlighterJSRAW">+--------------+-------------+------+-----+---------+-----------------------------+
| Field        | Type        | Null | Key | Default | Extra                       |
+--------------+-------------+------+-----+---------+-----------------------------+
| propinsi_id  | int(11)     | NO   | PRI | NULL    | auto_increment              |
| nama         | varchar(45) | NO   |     | NULL    |                             |
| dalam_negeri | tinyint(4)  | YES  |     | NULL    |                             |
| created_at   | datetime    | YES  |     | NULL    | on update CURRENT_TIMESTAMP |
| updated_at   | datetime    | YES  |     | NULL    |                             |
+--------------+-------------+------+-----+---------+-----------------------------+</pre>
<p>Kemudian kita buat sebuah form yang berisi dropdown, serta javascript yang digunakan untuk menginisialisasi select2 dengan request ajax. Option yang saya gunakan pada plugin select2 tersebut :</p>
<ol>
<li>Saya memberikan delay, sehingga request akan berjalan setelah 0.8 ms.</li>
<li>Minimum huruf yang harus di input adalah 3 huruf.</li>
<li>Saya tambahkan tombol untuk clear value pada select2 ini.</li>
</ol>
<pre class="lang:default decode:true EnlighterJSRAW">&lt;script type="text/javascript"&gt;
    $(function(){
       $('.select2').select2({
           minimumInputLength: 3,
           allowClear: true,
           placeholder: 'masukkan nama propinsi',
           ajax: {
              dataType: 'json',
              url: 'action/daftarProvinsi.php',
              delay: 800,
              data: function(params) {
                return {
                  search: params.term
                }
              },
              processResults: function (data, page) {
              return {
                results: data
              };
            },
          }
      }).on('select2:select', function (evt) {
         var data = $(".select2 option:selected").text();
         alert("Data yang dipilih adalah "+data);
      });
 });
&lt;/script&gt;
&lt;div class="row"&gt;
 &lt;div class="col-lg-4"&gt;
  &lt;form class="form-group"&gt;
   &lt;label&gt;Contoh Select2 Ajax&lt;/label&gt;
   &lt;select name="kabupaten" class="form-control select2"&gt;
    &lt;option value=""&gt;- pilih kabupaten -&lt;/option&gt;
   &lt;/select&gt;
  &lt;/form&gt;
 &lt;/div&gt;
&lt;/div&gt;</pre>
<p>Sehingga tampilannya adalah sebagai berikut.</p>
<div id="attachment_2740" style="width: 608px" class="wp-caption aligncenter"><img aria-describedby="caption-attachment-2740" decoding="async" loading="lazy" class="wp-image-2740" src="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_143.png" alt="Membuat Dropdown Select2 dengan Request Ajax dan Php" width="598" height="210" srcset="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_143.png 1036w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_143-300x105.png 300w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_143-768x270.png 768w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_143-1024x360.png 1024w" sizes="(max-width: 598px) 100vw, 598px" /><p id="caption-attachment-2740" class="wp-caption-text">Membuat Dropdown Select2 dengan Request Ajax dan Php</p></div>
<p>Buat file koneksi dengan menggunakan mysqli <strong>koneksi.php</strong>.</p>
<pre class="lang:default decode:true EnlighterJSRAW">&lt;?php
$connect = mysqli_connect('localhost','root','agusbiji','blog');
?&gt;</pre>
<p>Kemudian buat sebuah file php dengan nama <strong>daftarProvinsi.php</strong> yang berisi fungsi untuk menampilkan data daftar propinsi dari database. Berikut adalah contoh scriptnya.</p>
<pre class="lang:default decode:true EnlighterJSRAW ">&lt;?php
if($_SERVER['REQUEST_METHOD']=="GET"){
 require '../core/koneksi.php';
 daftarPropinsi($_GET['search']);
}

function daftarPropinsi($search){
 global $connect;

 if ($connect-&gt;connect_error) {
     die("Koneksi Gagal: " . $conn-&gt;connect_error);
 }

 $sql = "SELECT * FROM tb_propinsi WHERE nama LIKE '%$search%' AND dalam_negeri=1 ORDER BY nama ASC";
 $result = $connect-&gt;query($sql);

 if ($result-&gt;num_rows &gt; 0) {
     $list = array();
     $key=0;
     while($row = $result-&gt;fetch_assoc()) {
         $list[$key]['id'] = $row['propinsi_id'];
         $list[$key]['text'] = $row['nama']; 
     	$key++;
     }
     echo json_encode($list);
 } else {
     echo "hasil kosong";
 }
 $connect-&gt;close();
}

?&gt;</pre>
<p>Seperti yang bisa dilihat di atas, data yang akan kita kirimkan berupa array dengan key name <strong>id</strong> dan <strong>text, </strong>keyname ini sudah ditentukan di website resmi select2.</p>
<h2>Testing Kode Select2</h2>
<p>Setelah semua file sudah sesuai, kita coba untuk mengetes form tersebut. Saya akan memasukkan beberapa kata kunci pada pencarian di select2 ini. Dan Secara otomatis select2 akan menampilkan beberapa data yang relevan dengan kata kunci yang saya masukkan.</p>
<div id="attachment_2748" style="width: 610px" class="wp-caption aligncenter"><img aria-describedby="caption-attachment-2748" decoding="async" loading="lazy" class="wp-image-2748" src="https://mragus.com/wp-content/uploads/2017/08/Peek-2017-08-03-16-04.gif" alt="Membuat Dropdown Select2 dengan Request Ajax dan Php" width="600" height="299" /><p id="caption-attachment-2748" class="wp-caption-text">Membuat Dropdown Select2 dengan Request Ajax dan Php</p></div>
<div id="attachment_2749" style="width: 609px" class="wp-caption aligncenter"><img aria-describedby="caption-attachment-2749" decoding="async" loading="lazy" class="wp-image-2749" src="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_144.png" alt="Membuat Dropdown Select2 dengan Request Ajax dan Php" width="599" height="137" srcset="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_144.png 1418w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_144-300x68.png 300w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_144-768x175.png 768w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_144-1024x233.png 1024w" sizes="(max-width: 599px) 100vw, 599px" /><p id="caption-attachment-2749" class="wp-caption-text">Request Header</p></div>
<p>Kita juga bisa melihat request yang berjalan pada debugger.</p>
<div id="attachment_2750" style="width: 612px" class="wp-caption aligncenter"><img aria-describedby="caption-attachment-2750" decoding="async" loading="lazy" class="wp-image-2750" src="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_145.png" alt="Membuat Dropdown Select2 dengan Request Ajax dan Php" width="602" height="136" srcset="https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_145.png 1419w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_145-300x68.png 300w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_145-768x174.png 768w, https://mragus.com/wp-content/uploads/2017/08/aguswijisuhariono_145-1024x232.png 1024w" sizes="(max-width: 602px) 100vw, 602px" /><p id="caption-attachment-2750" class="wp-caption-text">Response</p></div>
<p>Mudah bukan <img src="https://s.w.org/images/core/emoji/14.0.0/72x72/1f600.png" alt="😀" class="wp-smiley" style="height: 1em; max-height: 1em;" /> , metode ini akan membuat load data pada form select2 menjadi lebih ringan untuk jumlah data yang banyak. Jika agan-agan membutuhkan source code, bisa cek link berikut <a href="https://mragus.com/source-code/">https://mragus.com/source-code/</a>. Semoga Tulisan saya ini dapat bermanfaat, <em>tetap belajar dan selamat mencoba</em>. Terimakasih.</p>
<p>The post <a rel="nofollow" href="https://mragus.com/membuat-dropdown-select2-dengan-request-ajax-dan-php/">Membuat Dropdown Select2 dengan Request Ajax dan Php</a> appeared first on <a rel="nofollow" href="https://mragus.com">Mr Agus</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mragus.com/membuat-dropdown-select2-dengan-request-ajax-dan-php/feed/</wfw:commentRss>
			<slash:comments>7</slash:comments>
		
		
			</item>
	</channel>
</rss>
