Pembangkit dokumentasi admin Django

Aplikasi admindocs Django menarik dokumentasi dari docstring dari model, tampilan etiket cetakan, dan penyaring cetakan untuk aplikasi apapun di INSTALLED_APPS dan membuat dokumentasi itu tersedia dari Django admin.

Ikhtisar

Untuk mengaktifkan admindocs, anda akan butuh melakukan berikut:

  • Tambah django.contrib.admindocs ke INSTALLED_APPS anda.
  • Tambah url(r'^admin/doc/', include('django.contrib.admindocs.urls')) ke urlpatterns anda. Pastikan itu disertakan sebelum masukan r'^admin/', sehingga permintaan itu pada /admin/doc/ tidak ditangani oleh masukan terakhir.
  • Pasang modul Python docutils (http://docutils.sf.net/).
  • Pilihan: Menggunakan Bookmark admindoc membutuhkan django.contrib.admindocs.middleware.XViewMiddleware untuk dipasang.

Sekali langkah-langkah tersebut lengkap, anda dapat mulai menjelajah dokumentasi dengan pergi ke antarmuka admin anda dan mengklik tautan "Documentation" di atas kanan halaman.

Dokumentasi pembantu

Markah khusus beikur dapat digunakan di docstring anda untuk dengan mudah membuat hyperlink ke komponen lain:

Komponen Django Peran reStructuredText
Model :model:`app_label.ModelName`
View :view:`app_label.view_name`
Tag templat :tag:`tagname`
Filter templat :filter:`filtername`
Templat :template:`path/to/template.html`

Acuan model

Bagian model dari halaman admindoc menggambarkan setiap model di sistem bersama dengan semua bidang dan metode tersedia pada itu. Hubungan ke model lain muncul sebagaihyperlink. Gambaran ditarik dari atribut help_text pada bidang atau dari docstring pada metode model.

Sebuah model dengan dokumentasi berguna mungkin terlihat seperti ini:

class BlogEntry(models.Model):
    """
    Stores a single blog entry, related to :model:`blog.Blog` and
    :model:`auth.User`.
    """
    slug = models.SlugField(help_text="A short label, generally used in URLs.")
    author = models.ForeignKey(
        User,
        models.SET_NULL,
        blank=True, null=True,
    )
    blog = models.ForeignKey(Blog, models.CASCADE)
    ...

    def publish(self):
        """Makes the blog entry live on the site."""
        ...

Lihat acuan

Setiap URL di situs anda mempunyai masukan terpisah di halaman admindocs, dan mengklik pada URL yang diberikan akan menunjukkan anda tampilan berhubungan. Hal-hal membantu anda dapat dokumentasikan di docstring fungsi tampilan anda termasuk:

  • Sebuah gambaran singkat dari apa yang tampilan lakukan.
  • konteks, atau daftar dari variabel tersedia di cetakan tampilan.
  • Nama dari cetakan atau cetakan-cetakan yang digunakan untuk tampilan itu.

Sebagai contoh:

from django.shortcuts import render

from myapp.models import MyModel

def my_view(request, slug):
    """
    Display an individual :model:`myapp.MyModel`.

    **Context**

    ``mymodel``
        An instance of :model:`myapp.MyModel`.

    **Template:**

    :template:`myapp/my_template.html`
    """
    context = {'mymodel': MyModel.objects.get(slug=slug)}
    return render(request, 'myapp/my_template.html', context)

Etiket cetakan dan acuan saringan

Bagian admindocs etiket and penyaring menggambarkan semua etiket dan penyaring yang datang dengan Django (faktanya, dokumentasi built-in tag reference dan built-in filter reference datang langsung dari halaman-halaman tersebut). Etiket atau penyaring apapun yang anda buat atau ditambahkan oleh aplikasi pihak-ketiga akan tampil di bagian-bgian ini juga.

Acuan cetakan

Selagi admindocs tidak menyertakan tempat untuk cetakan dokumen oleh mereka sendiri, jika anda menggunakan sintaksis :template:`path/to/template.html` di sebuah docstring halaman hasil akan memeriksa jalur dari cetakan itu dengan template loaders Django. Ini dapat menjadi cara mudah memeriksa jika cetakan ditentukan ada dan untuk menunjukkan dimana pada sistem berkas cetakan itu disimpan.

Disertakan Bookmarklet

Satu bookmarklet tersedia dari halaman admindocs:

Dokumentasi untuk laman ini
Buka dari laman apa saja ke laman dokumentasi untuk view yang menghasilkan laman tersebut.

Menggunakan bookmark ini mewajibkan bahwa XViewMiddleware dipasang dan bahwa anda masuk kedalam Django admin sebagai sebuah User dengan is_staff disetel menjadi True.