More

    Tutorial Django Bahasa Indonesia #6: Pengenalan Templates

    Pada artikel sebelumnya kita sudah belajar mengenai routing di django #5 . Dimana, pada tutorial tersebut kita sudah bagaimana cara menampilkan “Hello World” pada halaman homepage kita menggunakan HttpResponse. Pada kali ini, kita akan mencoba menampilkan sebuah pesan “Hello World” didalam sebuah template berupa HTML, dimana halaman html tersebut akan di render melalui django views.

    Tutorial Django Bahasa Indonesia #6: Pengenalan Templates

    Apa itu django templates?

    django templates adalah dokumen teks atau string Python yang ditandai menggunakan django template language. Django template akan dirender bersamaan dengan context. Dimana, semua variable yang berada di dalam context akan di tampilkan dihalaman HTML menggunakan tag double brackets {{  }}.

     

    Contoh penggunaan django templates

    Untuk bisa menggunakan template django, kita harus membuat sebuah folder terlebih dahulu dengan nama “templates” didalam app direktori. pengenalan templates

    Perlu diperhatikan, untuk penamaan folder “templates” harus sama persis dengan yang saya contohkan, karena apabila kita memberi nama lain seperti “template”, “temp” dsb maka django tidak bisa mendeteksi lokasi folder templates tersebut dan akan muncul error Template Does’nt Exist.

    Setelah itum kita akan membuat file baru dengan nama “index.html” didalam folder templates. Lalu buat struktur html dasar didalam file index.html tersebut. pengenalan templatesSekarang, kita akan mencoba menampilkan halaman index.html tersebut dibrowser.

    Caranya:

    Buka file views.py yang ada didalam app blog. Jika anda mengikuti tutorial sebelumnya, kita sudah mencoba menampilkan hello world menggunakan HttpResponse. Untuk menampilkan halaman index.html tadi, kita perlu mengubah HttpResponse tersebut menjadi render.

    return render(request, "index.html")
    

    Kode lengkapnya akan seperti berikut ini:

    from django.shortcuts import render
    from django.http import HttpResponse
    
    def index(request):
        return render(request, "index.html")
    
    

    index.html adalah nama file yang sudah kita buat tadi didalam folder templates.

    Sekarang simpan dan coba buka halaman browser. Maka akan muncul halaman html yang sudah kita buat tadi. pengenalan templates

    Jika terjadi error seperti pada gambar dibawah ini.pengenalan templates

    Maka, ada beberapa kemungkinan:

    1. Salah dalam penamaan file index.html pada bagian views.
    2. Kesalahan dalam pemberian nama folder templates.
    3. Pengaturan APP_DIRS pada settings.py menjadi False. Seharusnya Truepengenalan templates

    Sekarang kita akan mencoba passing data dari django views kedalam template html.

    Buat 2 variable dengan nama first_name dan juga last_name didalam views.py pada function index.

    first_name = 'Fikri'
    last_name = 'Aja'

    lalu kita akan passing kedua variable tersebut kedalam sebuah context.

    context = {
            'first_name':first_name,
            'last_name':last_name,
        }

    Pada bagian tanda petik, merupakan variable yang akan kita panggil didalam django template.

    Saat ini, context tersebut belum terender didalam template. Untuk melakukannya anda perlu menambahkan context didalam return.

    return render(request, "index.html", context)
    

    Maka kode lengkapnya akan seperti berikut ini

    from django.shortcuts import render
    from django.http import HttpResponse
    
    def index(request):
        first_name = 'Fikri'
        last_name = 'Aja'
    
        context = {
            'first_name':first_name,
            'last_name':last_name,
        }
        return render(request, "index.html", context)
    
    

    Sekarang, kita akan beralih kedalam file index.html. Seperti yang sudah saya katakan, untuk memanggil 2 variable first_name dan last_name didalam django template kita akan menggunakan double bracket {{}}

    masukkan kode berikut didalam file index.html

    <center>
        <p>
            Hello nama saya adalah {{first_name}} {{last_name}}
        </p>
    </center>

    Sekarang simpan dan refresh browser anda.

    Maka kita akan melihat sebuat string yang sudah kita buat sebelumnya didalam views.pengenalan templates

     

    Untuk menampilkan tanggal hari ini anda bisa menggunakan “now” pada template.

    saya lahir pada {% now 'd/m/Y' %}

    pengenalan templates

    Untuk variable dan tags lain anda bisa membaca langsung pada dokumentasi django melalui link berikut ini

    Cukup sekian tutorial django untuk topik pengenalan templates.

    Pada artikel berikutnya saya akan membahas tentang staticfiles dan juga integrasi bootstrap di django.

    Recent Articles

    [td_block_21]

    Related Articles

    3 Comments

    Leave A Reply

    Please enter your comment!
    Please enter your name here

    This site uses Akismet to reduce spam. Learn how your comment data is processed.

    Dapatkan konten terbaik dari kami!

    [tdn_block_newsletter_subscribe input_placeholder="Masukkan Alamat Email..." btn_text="Subscribe" tds_newsletter2-image="730" tds_newsletter2-image_bg_color="#c3ecff" tds_newsletter3-input_bar_display="" tds_newsletter4-image="731" tds_newsletter4-image_bg_color="#fffbcf" tds_newsletter4-btn_bg_color="#f3b700" tds_newsletter4-check_accent="#f3b700" tds_newsletter5-tdicon="tdc-font-fa tdc-font-fa-envelope-o" tds_newsletter5-btn_bg_color="#000000" tds_newsletter5-btn_bg_color_hover="#4db2ec" tds_newsletter5-check_accent="#000000" tds_newsletter6-input_bar_display="row" tds_newsletter6-btn_bg_color="#da1414" tds_newsletter6-check_accent="#da1414" tds_newsletter7-image="732" tds_newsletter7-btn_bg_color="#1c69ad" tds_newsletter7-check_accent="#1c69ad" tds_newsletter7-f_title_font_size="20" tds_newsletter7-f_title_font_line_height="28px" tds_newsletter8-input_bar_display="row" tds_newsletter8-btn_bg_color="#00649e" tds_newsletter8-btn_bg_color_hover="#21709e" tds_newsletter8-check_accent="#00649e" embedded_form_code="YWN0aW9uJTNEJTIybGlzdC1tYW5hZ2UuY29tJTJGc3Vic2NyaWJlJTIy" tds_newsletter="tds_newsletter1" tds_newsletter3-all_border_width="2" tds_newsletter3-all_border_color="#e6e6e6" tdc_css="eyJhbGwiOnsibWFyZ2luLWJvdHRvbSI6IjAiLCJib3JkZXItY29sb3IiOiIjZTZlNmU2IiwiZGlzcGxheSI6IiJ9fQ==" tds_newsletter1-btn_bg_color="#dd3333" tds_newsletter1-f_btn_font_family="406" tds_newsletter1-f_btn_font_transform="uppercase" tds_newsletter1-f_btn_font_weight="800" tds_newsletter1-f_btn_font_spacing="1" tds_newsletter1-f_input_font_line_height="eyJhbGwiOiIzIiwicG9ydHJhaXQiOiIyLjYiLCJsYW5kc2NhcGUiOiIyLjgifQ==" tds_newsletter1-f_input_font_family="406" tds_newsletter1-f_input_font_size="eyJhbGwiOiIxMyIsImxhbmRzY2FwZSI6IjEyIiwicG9ydHJhaXQiOiIxMSIsInBob25lIjoiMTMifQ==" tds_newsletter1-input_bg_color="#fcfcfc" tds_newsletter1-input_border_size="0" tds_newsletter1-f_btn_font_size="eyJsYW5kc2NhcGUiOiIxMiIsInBvcnRyYWl0IjoiMTEiLCJhbGwiOiIxMyJ9" content_align_horizontal="content-horiz-center"]