Web2py - Tampilan

kerangka web2py menggunakan Models, Controllers dan Viewsdalam aplikasinya. Ini menyertakan sintaks Python yang sedikit dimodifikasi di fileViews untuk kode yang lebih mudah dibaca tanpa batasan apa pun yang diberlakukan pada penggunaan Python yang tepat.

Tujuan utama web2py Viewadalah menyematkan kode python dalam dokumen HTML. Namun, ini menghadapi beberapa masalah, yaitu sebagai berikut -

  • Melarikan diri dari kode python tertanam dalam dokumen HTML.
  • Mengikuti indentasi berdasarkan Python, yang dapat memengaruhi aturan HTML.

Untuk keluar dari masalah, web2py menggunakan pembatas {{..}} di bagian tampilan. Pembatas membantu keluar dari kode python tertanam. Ini juga membantu dalam mengikuti aturan HTML indentasi.

Kode termasuk di dalamnya {{..}}pembatas menyertakan kode Python yang tidak diinginkan. Karena Python biasanya menggunakan lekukan untuk membatasi blok kode, kode yang tidak diinginkan dalam pembatas harus dijaga dengan cara yang benar. Untuk mengatasi masalah ini, web2py menggunakan“pass” kata kunci.

Blok kode yang dimulai dengan sebuah baris diakhiri dengan titik dua dan diakhiri dengan baris yang diawali dengan pass.

Note - pass adalah kata kunci Python, ini bukan kata kunci web2py.

Kode berikut menunjukkan implementasi kata kunci pass -

{{
   if num > 0:
      response.write('positive number')
   else:
      response.write('negative number')
      pass
}}

Pembantu HTML

web2py menyertakan kelas helper yang dapat digunakan untuk membangun HTML secara terprogram. Ini sesuai dengan tag HTML, disebut sebagai "pembantu HTML".

Misalnya -

[(A('Home', _href = URL('default', 'home')), False, None, []), ...]

Sini, A adalah helper yang sesuai dengan jangkar <a>tag HTML. Itu membangun jangkar HTML<a> tag secara terprogram.

Pembantu HTML terdiri dari dua jenis, yaitu positional dan named argumen.

  • Positional argumen diartikan sebagai objek yang berada di antara tag buka dan tutup HTML.

  • Named argumen dimulai dengan garis bawah diartikan sebagai tag HTML.

Pembantu juga berguna dalam serialisasi string, dengan ekstensi _str_dan metode xml. Misalnya -

>>> print str(DIV(“hello world”))

Keluaran

<div> hello world </div>

Note - Pembantu HTML menyediakan representasi sisi server dari Model Objek Dokumen (DOM).

Pembantu XML

XML disebut sebagai objek, yang merangkum teks yang tidak boleh di-escape. Teks mungkin atau mungkin tidak berisi XML yang valid.

Misalnya, untuk kode yang disebutkan di bawah ini, ini bisa berisi JavaScript.

>>> print XML('<script>alert("unsafe!")</script>')

Keluaran

<script> alert(“unsafe!”)</script>

Pembantu Bawaan

Ada banyak pembantu bawaan yang digunakan di web2py. Beberapa pembantu HTML built-in terdaftar seperti di bawah ini.

Nama Pemakaian Contoh
SEBUAH Helper ini digunakan untuk membangun tautan. Ini sesuai dengan tag jangkar
[
(A('Home', _href = URL('default', 'home')), False, None, []),
...]
B Pembantu ini membantu membuat isi teks menjadi tebal.
B('<hello>', XML('<i>world</i>'), _class = 'test', _id = 0)
TUBUH Pembantu ini membuat badan halaman. Ini juga termasuk operator perkalian untuk meningkatkan jumlah istirahat.
BR()
KODE Itu melakukan penyorotan sintaks untuk kode Python, C, C ++ dan web2py. Helper ini juga memiliki kemampuan untuk menautkan dokumentasi API.
CODE('print "hello"', language = 'python').xml()
FIELDSET Ini menciptakan bidang masukan bersama dengan labelnya.
FIELDSET('Height:', INPUT(_name = 'height'), _class = 'test')
KEPALA Ini membantu dalam menandai tag <head> dari halaman HTML.
HEAD(TITLE('<hello>'))
IMG Ini membantu dalam menyematkan gambar untuk halaman HTML tertentu.
IMG(_src = 'http://example.com/image.png',_alt = 'test')

Pembantu Kustom

Pembantu ini digunakan untuk menyesuaikan tag sesuai kebutuhan. web2py menggunakan pembantu khusus berikut -

MENANDAI

web2py menggunakan TAG sebagai generator tag universal. Ini membantu dalam menghasilkan tag XML yang disesuaikan. Sintaks umumnya adalah sebagai berikut -

{{ = TAG.name('a', 'b', _c = 'd')}}

Ini menghasilkan kode XML sebagai: <name c = "d"> ab </name>

TAG adalah objek dan TAG.nameatau TAG['name']merupakan fungsi yang mengembalikan kelas pembantu sementara.

TIDAK BISA

Helper ini membuat daftar item daftar atau nilai item menu, menghasilkan struktur seperti pohon yang mewakili menu. Daftar item menu adalah dalam bentukresponse.menu. Misalnya -

print MENU([['One', False, 'link1'], ['Two', False, 'link2']])

Outputnya akan ditampilkan sebagai berikut -

<ul class = "web2py-menu web2py-menu-vertical">
   <li><a href = "link1">One</a></li>
   <li><a href = "link2">Two</a></li>
</ul>

MEMPERCANTIK

Ini membantu dalam membangun representasi objek gabungan, termasuk daftar dan kamus. Sebagai contoh,

{{ = BEAUTIFY({"a": ["hello", XML("world")], "b": (1, 2)})}}

Ini mengembalikan objek XML yang dapat diserialkan ke XML, dengan representasi argumen konstruktornya. Dalam hal ini, representasi akan menjadi -

{"a": ["hello", XML("world")], "b": (1, 2)}

Outputnya akan ditampilkan sebagai -

<table>
   <tr>
      <td>a</td>
      <td>:</td>
      <td>hello<br />world</td>
   </tr>
   
   <tr>
      <td>b</td>
      <td>:</td>
      <td>1<br />2</td>
   </tr>
</table>

Rendering DOM Sisi Server

Rendering sisi server memungkinkan pengguna melakukan praperenderan status awal komponen web2py. Semua pembantu turunan menyediakan elemen penelusuran dan elemen untuk merender DOM di sisi server.

Itu elementmengembalikan elemen anak pertama yang cocok dengan kondisi yang ditentukan. Di samping itu,elementsmengembalikan daftar semua anak yang cocok. Keduanya menggunakan sintaks yang sama.

Ini dapat ditunjukkan dengan contoh berikut -

a = DIV(DIV(DIV('a', _id = 'target',_class = 'abc')))
d = a.elements('div#target')
d[0][0] = 'changed'
print a

Outputnya diberikan sebagai -

<div><div><div id = "target" class = "abc">changed</div></div></div>

Tata letak halaman

Tampilan digunakan untuk menampilkan output ke pengguna akhir. Itu dapat meluas serta mencakup pandangan lain juga. Ini akan menerapkan struktur seperti pohon.

Contoh - “index.html” meluas ke “layout.html” yang dapat mencakup “menu.html” yang pada gilirannya mencakup “header.html”.

{{extend 'layout.html'}}
<h1>Hello World</h1>
{{include 'page.html'}}

Contoh

Pada bab sebelumnya, kami membuat model dan pengontrol untuk modul perusahaan. Sekarang, kami akan fokus pada pembuatan tampilan, yang membantu dalam menampilkan tampilan data.

Secara default, tampilan di web2py menyertakan layout.html dan index.html, yang mendefinisikan keseluruhan bagian menampilkan data.

{{extend 'layout.html'}}
<h2>Companies</h2>

<table>
   {{for company in companies:}}
   <tr>
      <td>{{ = A(company.name, _href = URL('contacts', args = company.id))}}</td>
      <td>{{ = A('edit', _href = URL('company_edit', args = company.id))}}</td>
   </tr>
   
   {{pass}}
   <tr>
      <td>{{ = A('add company', _href = URL('company_create'))}}</td>
   </tr>
	
</table>

Outputnya adalah sebagai berikut -