MasRud.com
Rudi — 26 Desember 2018

Membuat Format Tanggal Ala Instagram dengan PHP

Jika kamu bertanya-tanya bagaimana cara membuat tampilan waktu seperti pada aplikasi Instagram menggunakan PHP, kamu berada pada tempat yang tepat, karena di posting kali ini saya akan membagikan tutorialnya.

Untuk memformat tampilan tanggal kita hanya perlu membuat sebuah fungsi. Fungsi tersebut nantinya akan menerima parameter tanggal yang akan diubah menjadi tampilan waktu yang mirip dengan waktu posting status di Instagram.

Contohnya seperti gambar utama posting ini.

Sekarang kita lanjut ke tutorial. Pertama kita bahas bagaimana algoritma dan logikanya kemudian dilanjutkan dengan penerapan pada koding.

Logika dan Algoritma

Kita cari tahu dulu perbedaan waktu tanggal yang ingin diformat $time_ago dengan tanggal saat ini $current_time dan hasilnya kita simpan dalam sebuah variabel $time_difference.

Kemudian buat variabel baru sesuai dengan satuan waktu $minutes, $hours, $days, $weeks, $months dan $years.

Variabel tersebut akan digunakan untuk menyimpan hasil pembulatan dari perbedaan waktu $time_difference dibagi dengan jumlah detik/satuan waktu.

Tabel jumlah detik/satuan waktu
Satuan WaktuJumlah Detik
Menit60
Jam3600
Hari86400
Minggu604800
Bulan2629440
Tahun31553280

Kemudian gunakan percabangan if dan else untuk memformat tampilan tanggal pada setiap satuan waktu.

Penerapan pada Koding

Silakan copy kode di bawah ini dan simpan pada project aplikasi kamu.

Untuk menggunakannya kita cukup memanggil fungsi igDate($datetime) dan memasukkan parameter tanggal.

Contoh:

<?php echo igDate("2018-12-25 12:10:45"); ?>

Format tampilan waktu pada kode sebelumnya tidak akan pernah menampilkan tanggal sebenarnya (25 Desember 2018).

Agar fungsi tersebut dapat menampilkan tanggal sebenarnya, maka kita dapat menandai batas waktu tertentu pada percabangan if else.

Jadi jika sudah mencapai batas waktu yang telah kita atur, maka format tampilan waktu berubah menjadi tanggal sebenarnya (tanggal bulan tahun).


Kategori: PHP
Komentar