Skip to content

emka.web.id

menulis pengetahuan – merekam peradaban

Menu
  • Home
  • Tutorial
  • Search
Menu

Tutorial Panada: Membuat Website Sederhana dengan Panada

Posted on July 23, 2013

Pendahuluan

Untuk tutorial kali ini, kita akan membuat sebuah website sederhana tanpa akses database sebagai demonstrasi kemampuan dasar dan alur dasar membuat Web/Applikasi berbasis Panada Framework. Untuk dapat mengikuti tutorial kali ini, minimal anda sudah menguasai konsep dasar OOP pada PHP dan Instalasi Panada Framework.

Langkah-langkah

1. Install Panada Framework

2. Buat folder kerja

Folder kerja yang dimaksud disini adalah folder aplikasi berbasis Panada akan dikembangkan. Perlu diingat, Panada bisa menampung banyak aplikasi/website dalam satu engine/system baik dengan nama domain yang sama maupun berbeda.

Untuk tutorial kali ini, silakan buat folder bernama: websiteku. Struktur folder didalamnya adalah sebagai berikut:

panada-simpleweb-1

3. Buat File bootstrap/loader utama engine Panada. Silakan buat file index.php pada folder websiteku. Isi dari file index.php tersebut adalah:

[sourcecode language=”php”]

<?php
// Sets the default timezone used by all date/time. Adjust to your location
date_default_timezone_set(‘Asia/Jakarta’);

// You can adjust this following constants if necessary.

// The APP constant is where your application folder located.
define(‘APP’, dirname(__FILE__) . ‘/’);

// The INDEX_FILE constant is this default file name.
define(‘INDEX_FILE’, basename(__FILE__));

// And the GEAR constant is where panada folder located.
define(‘GEAR’, ‘../panada/’);

require_once GEAR.’Gear.php’;

// To sets which PHP errors are reported just like documented in this page
// http://php.net/manual/en/function.error-reporting.php
// You can pass a parameter into the Gear class.

// Turn off all errors reporting – production use.
// new Gear(0);

// By default all errors will displayed – development use.
new Gear;

[/sourcecode]

4. Buat file konfigurasi utama.

Silakan tulis source code berikut dan simpan sebagai file main.php di folder /websiteku/config.
[sourcecode language=”php”]
<?php

return array(

‘defaultController’ => ‘Home’,

// Just put null value if you has enable .htaccess file
‘indexFile’ => INDEX_FILE . ‘/’,

‘module’ => array(
‘path’ => APP,
‘domainMapping’ => array(),
),

‘vendor’ => array(
‘path’ => GEAR.’vendors/’
),

‘alias’ => array(
/*
‘controller’ => array(
‘class’ => ‘Alias’,
‘method’ => ‘index’
),
*/
‘method’ => ‘alias’
),
);
[/sourcecode]

NB. Yang patut dicatat pada konfigurasi ini adalah, Controller Default Panada telah kita set pada Controller Home.

5. Membuat Controller Home (controller default)

Silakan tuliskan source code berikut dan simpan sebagai Home.php pada folder /websiteku/Controllers/
[sourcecode language=”php”]
<?php
namespace Controllers;
use Resources, Models;

class Home extends Resources\Controller
{
public function index()
{
echo "Test controller default berhasil";
}
}
[/sourcecode]

6. Cek tampilan dari Controller Home (sebagai dasaran berpijak)

(di http://localhost/panada/websiteku/). Contoh tampilan hasil:
panada-simpleweb-2

7. Latihan melempar data dari Controller ke View.

NB. Ingat, Controller adalah skrip yang digunakan untuk memproses request dari User (bayangkan saja dari URL yang dibuka user) kemudian View adalah skrip berisi tampilan yang akan dilihat user. Dalam konsep MVC maupun HMVC, file View SEBAIKNYA bersih dari proses olah data. Data, sebaiknya diolah di Controller.

Buka kembali file Home.php di folder /websiteku/Controllers. Ubah sehingga menjadi seperti berikut:
[sourcecode language=”php”]
<?php
namespace Controllers;
use Resources, Models;

class Home extends Resources\Controller
{
public function index()
{
$data[‘nama’] = ‘Nama saya adalah Emka’;

$this->output(‘home’, $data);
}
}
[/sourcecode]

yang patut kita perhatikan adalah perubahan logika pada fungsi index(). Kini, data yang direpresentasikan dalam bentuk array akan kita isi dan kita lempar ke file view untuk ditampilkan. Dalam contoh ini, data ‘nama’ akan kita isi dan akan kita lempar ke file view.

Snippet:
[sourcecode language=”php”]
//contoh isian data
$data[‘nama’] = ‘Nama saya adalah Emka’;

//cara default untuk meload file view beserta data-nya
//template: $this->output(‘namafileview’, dataviewyangdilempar);

$this->output(‘home’, $data);
[/sourcecode]

kemudian buat file view yang akan menjadi sasaran pelemparan data. Misalnya file: /websiteku/views/home.php (ingat, sesuai gaya tulis yang dianjurkan dan nama yang diset di Controller).

Isi dari file view tersebut adalah:
[sourcecode language=”php”]
<?php
echo $nama;
?>
[/sourcecode]

hasil tampilan di browser:
panada-simpleweb-3

Jadi, untuk menampilkan data pada file view, anda bisa melakukan echo terhadap data yang dimaksud dengan acuan, jika pada Controller tertulis

$data['nama']

sebagai array dan key array, maka pada file view, anda tulis

echo $nama;

(menyesuaikan key array yang dimaksud). Jika nanti ada

$data['jumlah_siswa'];

maka pada file view anda akan tulis:

echo $jumlah_siswa;

.

8. Mulai Gunakan Template Web/Template HTML Sederhana

Untuk memulai menggunakan template web bagi website berbasis Panada, anda cukup menyalin source dari template web yang dimaksud ke file view (yang sesuai).

Sebagai contoh, saya modifikasi file /websiteku/views/home.php (file view default dari Controller Home dan fungsi index()) dengan memasukkan template html sebagai berikut:
[sourcecode language=”html”]
<html>
<head>
<title>Websiteku</title>
<style>
#container
{
margin: 0 auto;
width: 900px;
background: #fff;
}

#header
{
background: #ccc;
padding: 20px;
}

#header h1 { margin: 0; }

#navigation
{
float: left;
width: 900px;
background: #333;
}

#navigation ul
{
margin: 0;
padding: 0;
}

#navigation ul li
{
list-style-type: none;
display: inline;
}

#navigation li a
{
display: block;
float: left;
padding: 5px 10px;
color: #fff;
text-decoration: none;
border-right: 1px solid #fff;
}

#navigation li a:hover { background: #383; }

#content-container
{
float: left;
width: 900px;
background: #fff url(/wp-content/uploads/layout-two-fixed-background.gif) repeat-y 100% 0;
}

#content
{
clear: left;
float: left;
width: 560px;
padding: 20px 0;
margin: 0 0 0 30px;
display: inline;
}

#content h2 { margin: 0; }

#aside
{
float: right;
width: 240px;
padding: 20px 0;
margin: 0 20px 0 0;
display: inline;
}

#aside h3 { margin: 0; }

#footer
{
clear: both;
background: #ccc;
text-align: right;
padding: 20px;
height: 1%;
}
</style>
</head>
<body>
<div id="container">
<div id="header">
<h1>
Site name
</h1>
</div>
<div id="navigation">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Services</a></li>
<li><a href="#">Contact us</a></li>
</ul>
</div>
<div id="content-container">
<div id="content">
<h2>
Page heading
</h2>
<p>
Lorem ipsum dolor sit amet consect etuer adipi scing elit sed diam nonummy nibh euismod tinunt ut laoreet dolore magna aliquam erat volut. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.
</p>
<p>
Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
</p>
<p>
Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
</p>
</div>
<div id="aside">
<h3>
Aside heading
</h3>
<p>
Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan.
</p>
</div>
<div id="footer">
Copyright © Site name, 20XX
</div>
</div>
</div>
</body>
</html>
[/sourcecode]

sehingga tampil halaman sebagai berikut:
panada-simpleweb-4

Demi efektivitas dan kerapian pengerjaan, sebaiknya file view dengan konsep template HTML ini kita pecah menjadi beberapa section besar, yaitu: header, content, sidebar, dan footer.

Dari file view home.php diatas, kita akan pecah menjadi 4 bagian yaitu header, content, sidebar dan footer.

Untuk header:
[sourcecode language=”html”]
<html>
<head>
<title>Websiteku</title>
<style>
#container
{
margin: 0 auto;
width: 900px;
background: #fff;
}

#header
{
background: #ccc;
padding: 20px;
}

#header h1 { margin: 0; }

#navigation
{
float: left;
width: 900px;
background: #333;
}

#navigation ul
{
margin: 0;
padding: 0;
}

#navigation ul li
{
list-style-type: none;
display: inline;
}

#navigation li a
{
display: block;
float: left;
padding: 5px 10px;
color: #fff;
text-decoration: none;
border-right: 1px solid #fff;
}

#navigation li a:hover { background: #383; }

#content-container
{
float: left;
width: 900px;
background: #fff url(/wp-content/uploads/layout-two-fixed-background.gif) repeat-y 100% 0;
}

#content
{
clear: left;
float: left;
width: 560px;
padding: 20px 0;
margin: 0 0 0 30px;
display: inline;
}

#content h2 { margin: 0; }

#aside
{
float: right;
width: 240px;
padding: 20px 0;
margin: 0 20px 0 0;
display: inline;
}

#aside h3 { margin: 0; }

#footer
{
clear: both;
background: #ccc;
text-align: right;
padding: 20px;
height: 1%;
}
</style>
</head>
<body>
<div id="container">
<div id="header">
<h1>
Site name
</h1>
</div>
<div id="navigation">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Services</a></li>
<li><a href="#">Contact us</a></li>
</ul>
</div>
[/sourcecode]

simpan sebagai /websiteku/views/header.php

untuk bagian Content:
[sourcecode language=”html”]
<div id="content-container">
<div id="content">
<h2>
Page heading
</h2>
<p>
Lorem ipsum dolor sit amet consect etuer adipi scing elit sed diam nonummy nibh euismod tinunt ut laoreet dolore magna aliquam erat volut. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.
</p>
<p>
Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
</p>
<p>
Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
</p>
</div>
[/sourcecode]
simpan sebagai file /websiteku/views/content.php

untuk bagian Sidebar (bilah kanan)
[sourcecode language=”html”]
<div id="content-container">
<div id="content">
<h2>
Page heading
</h2>
<p>
Lorem ipsum dolor sit amet consect etuer adipi scing elit sed diam nonummy nibh euismod tinunt ut laoreet dolore magna aliquam erat volut. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.
</p>
<p>
Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
</p>
<p>
Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
</p>
</div>
[/sourcecode]

simpan sebagai /websiteku/views/content.php

Untuk bagian footer:
[sourcecode language=”html”]

<div id="footer">
Copyright © Site name, 20XX
</div>
</div>
</div>
</body>
</html>
[/sourcecode]

simpan sebagai file /websiteku/views/footer.php.

Kemudian modifikasi method di Controller Home, sehingga kita akan meload 4 bagian file tersebut:
[sourcecode language=”php”]
public function index()
{
$data[‘nama’] = ‘Nama saya adalah Emka’;

$this->output(‘header’, $data);
$this->output(‘content’, $data);
$this->output(‘sidebar’, $data);
$this->output(‘footer’, $data);
}
[/sourcecode]

Silakan cek di Browser, seharusnya tampilan yang dihasilkan sama dengan tampilan sebelum dipecah per bagian.

9. Ubah string statis di file view menjadi lebih dinamis dengan mengambil/menuliskan data dari Controller.

Contoh data yang akan kita gunakan (kita set di Controller dan akan ditulis di view).

Dalam file Controller Home.php
[sourcecode language=”php”]
public function index()
{
$data[‘judul_web’] = ‘Websiteku.com’;
$data[‘nama_web’] = ‘Websiteku.com – Website berbasis Panada Framework’;

$this->output(‘header’, $data);
$this->output(‘content’, $data);
$this->output(‘sidebar’, $data);
$this->output(‘footer’, $data);
}
[/sourcecode]

dan file view-nya (yaitu bagian header.php):
[sourcecode language=”php”]
<html>
<head>
<title><?php echo $judul_web;?></title>
<style>
#container
{
margin: 0 auto;
width: 900px;
background: #fff;
}

#header
{
background: #ccc;
padding: 20px;
}

#header h1 { margin: 0; }

#navigation
{
float: left;
width: 900px;
background: #333;
}

#navigation ul
{
margin: 0;
padding: 0;
}

#navigation ul li
{
list-style-type: none;
display: inline;
}

#navigation li a
{
display: block;
float: left;
padding: 5px 10px;
color: #fff;
text-decoration: none;
border-right: 1px solid #fff;
}

#navigation li a:hover { background: #383; }

#content-container
{
float: left;
width: 900px;
background: #fff url(/wp-content/uploads/layout-two-fixed-background.gif) repeat-y 100% 0;
}

#content
{
clear: left;
float: left;
width: 560px;
padding: 20px 0;
margin: 0 0 0 30px;
display: inline;
}

#content h2 { margin: 0; }

#aside
{
float: right;
width: 240px;
padding: 20px 0;
margin: 0 20px 0 0;
display: inline;
}

#aside h3 { margin: 0; }

#footer
{
clear: both;
background: #ccc;
text-align: right;
padding: 20px;
height: 1%;
}
</style>
</head>
<body>
<div id="container">
<div id="header">
<h1>
<?php echo $nama_web;?>
</h1>
</div>
<div id="navigation">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Services</a></li>
<li><a href="#">Contact us</a></li>
</ul>
</div>
[/sourcecode]

NB. Data dari controller yang kita gunakan untuk sementara ini adalah ‘judul_web’ dan ‘nama_web’.

Silakan cek di Browser. Seharusnya tampil:
panada-simpleweb-5

10. Mengubah isi Link Navigasi Situs sesuai keinginan.

Perhatikan pada file header.php
[sourcecode language=”html”]
<div id="navigation">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Services</a></li>
<li><a href="#">Contact us</a></li>
</ul>
</div>
[/sourcecode]

Dengan sedikit logika tambahan dan pengaturan awal data link navigasi bisa kita set di Controller dan dijabarkan/dituliskan pada file view yang dimaksud.

Dalam controller tambahkan:
[sourcecode language=”php”]
$data[‘navigasi’] = array(‘about’, ‘produk’, ‘kontak’);
[/sourcecode]

dan pada file view (header.php) ubah skrip sebelumnya menjadi:
[sourcecode language=”php”]
<div id="navigation">
<ul>
<li><a href="<?php echo $this->location(‘Home’);?>">Home</a></li>
<?php
foreach($navigasi as $nav)
{
echo ‘<li><a href="’.$this->location(‘home/’.$nav).’">’.$nav.'</a></li>’;
}
?>
</ul>
</div>
[/sourcecode]

Disini kita memanfaatkan Global Method Panada yaitu $this->location();. Dengan menuliskan $this->location(‘home/kontak’); maka URL yang digenerate adalah: http://localhost/websiteku/index.php/home/kontak.

Cek di browser, seharusnya akan tampil seperti berikut:
panada-simpleweb-6

11. Membuat halaman about

Untuk membuat halaman about, silakan buka controller Home dan tambahkan method/fungsi berikut:
[sourcecode language=”php”]
public function about()
{
$data[‘judul_web’] = ‘Websiteku.com – About’;
$data[‘nama_web’] = ‘Websiteku.com – Website berbasis Panada Framework’;
$data[‘navigasi’] = array(‘about’, ‘produk’, ‘kontak’);

$this->output(‘header’, $data);
$this->output(‘about’, $data);
$this->output(‘sidebar’, $data);
$this->output(‘footer’, $data);
}
[/sourcecode]

perbedaan dari method/fungsi index() adalah dalam hal meload konten, dimana tidak meload file content.php tapi file about.php, karena file about.php akan kita jadikan file view untuk halaman about.

Buat file about.php di folder /websiteku/views/.
[sourcecode language=”php”]
<div id="content-container">
<div id="content">
<h2>
About <?php echo $nama_web;?>
</h2>
<p>
Lorem ipsum dolor sit amet consect etuer adipi scing elit sed diam nonummy nibh euismod tinunt ut laoreet dolore magna aliquam erat volut. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.
</p>
<p>
Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
</p>
<p>
Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
</p>
</div>
[/sourcecode]

dalam source diatas, heading/judul halaman sudah kita Set sebagai About {nama_web}, dimana nama_web diambil dari data yang dilempar oleh Controller Home.

Coba buka link About dan seharusnya tampil:
panada-simpleweb-7

Ulangi hal yang sama untuk halaman produk dan halaman kontak. Anda tinggal tambahkan method/fungsi produk() dan kontak() dengan isi yang kurang lebih sama seperti source about() diatas, dengan perbedaan pada file view yang di load, misalnya menjadi $this->output(‘produk’,$data); atau $this->output(‘kontak’,$data);.

Download

Download source code tutorial ini: websiteku.zip

Terbaru

  • Video Melolo Cuma Layar Hitam? Ini Trik Ampuh Mengatasinya, Pasti Berhasil!
  • Mau Simpan Video Twitter dan TikTok Tanpa Aplikasi? Begini Cara Praktis Pakai VidsSave!
  • Mau Gaji Dolar? Gini Caranya Tembus Kerja di Australia, Jangan Sampai Salah Visa!
  • Belum Tahu? Inilah Fakta MigoReels, Katanya Nonton Drama Bisa Dapat Rp700 Ribu!
  • Apa Itu Event Invite Friends CapCut? Ini Pengertian dan Cara Kerjanya Biar Cuan
  • Apa Itu MJ di FF? Ini Pengertian, Asal-Usul, dan Risiko di Balik Istilah Tersebut
  • Apa Itu Pengertian Penonaktifan SPayLater? Ini Durasi Blokir Akibat Telat Bayar
  • Apa Itu Rasio Gambar Ukuran 1:1 di Canva? Ini Pengertian dan Cara Buatnya
  • Pengiriman Shopee Express Hemat itu Berapa Lama? Ini Pengertian dan Estimasi Sampainya
  • Android 2025: Aplikasi Baru dan Smartphone Impian yang Akan Datang!
  • Apa Itu Google AI Pro Ultra? Ini Pengertian dan Penjelasan Lengkapnya
  • Apa Itu Error Gagal Kirim Nilai RDM 3.1? Ini Pengertian dan Solusi Mengatasinya
  • Facebook Mulai Batasi Link Eksternal Cuma 2 Sebulan! Ini Trik Mengatasinya
  • Cara Nonton Tensura Season 4! Bakal Tayang April 2026 dengan Format 5 Cour
  • Belum Tahu? Inilah Trik Supaya Live TikTok Kalian Aman dan Banjir Cuan
  • Pixel 8 Dapatkan Mode Panorama Baru! Hasil Foto Lebih Luas & Lebih Kreatif
  • Apa Itu AppLocker? Ini Pengertian dan Cara Mengamankan Windows 11 Kalian dari Skrip Jahat
  • Cara Membuat Riwayat Copilot Kamu Tetap Bersih dan Rapi!
  • Game & Aplikasi Android Terbaik Saat Diskon Liburan Natal! Jangan Ketinggalan!
  • Apa Itu Game Prison Escape Journey? Ini Pengertian dan Cara Mainnya untuk Pemula
  • “Listrik Gratis” dari Solar Panel Cuma Mitos?! Ini Sisi Gelap PLTS
  • Samsung Galaxy Z-Fold: Uji Jatuh Bebas yang Mengguncang Keandalan Lipatannya
  • Google One 2026: Apa yang Akan Jadi Fitur Utama dan Harga yang Diharapkan?
  • Apa Itu Error 0x800704f8? Ini Pengertian dan Cara Mengatasinya
  • Android Akhirnya Dapat GPS Darurat di India! Setelah Hampir 10 Tahun
  • Apa Itu GetContact Premium? Ini Pengertian dan Cara Daftarnya
  • Android Maze Figure: Koleksi Baru Google yang Bikin Penggemar Bergairah!
  • Google Update Besar-besaran Desember 2025: Apa yang Akan Memengaruhi Pengalaman Anda?
  • Masih Pusing Hitung Gaji Manual? Waktunya Pakai Aplikasi HR
  • Apa Itu Dustruco? Ini Pengertian dan Cara Pasangnya di HP Kalian
  • Apa itu Cosmic Desktop: Pengertian dan Cara Pasangnya di Ubuntu 26.04?
  • Apa Itu Auvidea X242? Pengertian Carrier Board Jetson T5000 dengan Dual 10Gbe
  • Elementary OS 8.1 Resmi Rilis: Kini Pakai Wayland Secara Standar!
  • Apa Itu Raspberry Pi Imager? Pengertian dan Pembaruan Versi 2.0.3 yang Wajib Kalian Tahu
  • Performa Maksimal! Ini Cara Manual Update Ubuntu ke Linux Kernel 6.18 LTS
  • Begini Cara Menjalankan Notebook Machine Learning di Databricks, Gratis dan Tanpa Ribet!
  • Apa Itu PeakAI? Ini Pengertian dan Cara Menghasilkan Uang dari Kolaborasi TikTok
  • Inilah Cara Ubah Rutinitas Browsing Lebih Produktif dengan Perplexity Comet (AI Browser)
  • Inilah Cara Kuasai Materi Sulit dalam Hitungan Menit Pakai Google NotebookLM: Tutorial Lengkap
  • Inilah Cara Membuat AI Agent Cerdas dan Memantaunya Menggunakan LangGraph dan LangSmith
  • Apa Itu Raccoon0365? Ini Pengertian dan Bahaya Platform Phishing Microsoft
  • Apa Itu Raccoon Framework? Ini Pengertian dan Asal Usulnya
  • Apa Itu Serangan Phishing OAuth di Microsoft 365? Ini Definisi dan Cara Kerjanya
  • Apa Itu Distribusi Malware Via YouTube? Ini Pengertian dan Bahayanya Buat Kalian
  • Apa Itu Undang-Undang NDAA? Ini Pengertian dan Dampaknya Bagi Cyber Command Amerika Serikat
Beli Morning Star Kursi Gaming/Kantor disini: https://s.shopee.co.id/805iTUOPRV
Beli Pemotong Rumput dengan Baterai IRONHOOF 588V Mesin Potong Rumput 88V disini https://s.shopee.co.id/70DBGTHtuJ

©2025 emka.web.id | Design: Newspaperly WordPress Theme