Rumah > pembangunan bahagian belakang > Tutorial Python > Corak Pengaturcaraan Meta Runtime dalam Python ini Menarik

Corak Pengaturcaraan Meta Runtime dalam Python ini Menarik

Patricia Arquette
Lepaskan: 2024-12-23 21:40:16
asal
922 orang telah melayarinya

This Runtime Meta-Programming Pattern in Python is Interesting

Latar belakang

Saya sedang mengusahakan rangka kerja UI yang dibina di atas Pyodide, yang dipanggil Zenaura. Baru-baru ini, saya perhatikan bahawa antara muka pembina — cara utama pengguna mencipta elemen UI — agak terlalu rumit dan tidak menarik. Walaupun ia mengabstrakkan antara muka asas yang lebih rumit untuk berinteraksi dengan struktur data "Nod" DOM ​​maya Zenaura, ia masih tidak memuaskan. Saya ingin memudahkan perkara dan memberikan pengguna pengalaman yang lebih bersih, lebih intuitif, sambil meletakkan asas untuk berpotensi membangunkan pengkompil untuk sintaks yang benar-benar baharu. Sesuatu seperti ini:

div(attr1=val1, child1, child2, child3)
Salin selepas log masuk

Pernyataan Masalah

Antara muka pembina semasa terlalu tahap rendah dan tidak mesra pengguna. Pengguna seharusnya tidak perlu berinteraksi dengan sesuatu seperti ini:

builder = Builder(name__)
if children:
    builder.with_children(*children)
if attributes:
    builder.with_attributes(**attributes)
if text:
    builder.with_text(text)
# print("data", builder.node.children, builder.node.attributes)
return builder.build()
Salin selepas log masuk

Sebaliknya, mereka sepatutnya boleh menggunakan sintaks yang lebih bersih dan mudah dibaca seperti:

div(id="some-id", h1("text"), p("text"))
Salin selepas log masuk

Melihat pada dokumen MDN, terdapat 91 teg HTML, dengan kemungkinan penambahan atau penamatan. Saya pada mulanya mempertimbangkan untuk menjana kod secara dinamik untuk memudahkan proses ini, tetapi semasa ia berfungsi, ia bukan penyelesaian yang paling praktikal. Matlamat utama adalah untuk menunjukkan docstrings setiap kali pengguna memanggil fungsi, tetapi pendekatan yang dijana secara dinamik memperkenalkan beberapa cabaran, seperti kekurangan autolengkap.

Pendekatan Dinamik

Berikut ialah kod yang dijana secara dinamik yang saya uji:

tag_config = {
    # root elements
    "html": "nestable",
    "main": "nestable",
    "body": "nestable",
}

tags_factory = {
    "nestable": lambda name__: f"""
{name__} = partial(nestable, "{name__}")
{name__}.__doc__ = nestable.__doc__
""",
    "textable": lambda name__: f"""
{name__} = partial(textable, "{name__}")
""",
    "self_closing": lambda name__: f"""
{name__} = partial(self_closing, "{name__}")
""",
    "nestable_no_attrs": lambda name__: f"""
{name__} = partial(nestable_no_attrs, "{name__}")
"""
}

for k, v in tag_config.items():
    exec(tags_factory[v](k), globals())
Salin selepas log masuk

Ini berfungsi dengan baik dari segi kefungsian tetapi kurang pada kebolehgunaan. Kelemahan utama ialah kekurangan autolengkap, kerana kod itu disuntik semasa runtime. Walau bagaimanapun, teg HTML itu sendiri agak mudah, jadi ini tidak begitu membimbangkan buat masa ini.

Faedah dan Had

Salah satu kelebihan ketara pendekatan ini ialah fleksibiliti. Menyokong atau menafikan elemen html dalam Zenaura adalah semudah menambah atau mengalih keluar pasangan nilai kunci daripada kamus tag_config. Ini adalah cara yang mudah untuk menyesuaikan diri dengan perubahan dalam teg HTML dari semasa ke semasa.

Selain itu, satu-satunya had adalah dengan autolengkap dan menunjukkan rentetan dokumen kepada pengguna, saya rasa ini adalah pertukaran yang baik untuk dibuat memandangkan elemen html cukup asas.

Walau bagaimanapun, pertukaran datang dalam bentuk kebolehgunaan: tanpa pelengkapan automatik, pengguna mungkin menghadapi cabaran apabila berinteraksi dengan antara muka. Walau bagaimanapun, saya percaya ini adalah titik permulaan yang baik untuk bereksperimen dengan cara baharu untuk mengendalikan elemen tag dalam Zenaura.

Atas ialah kandungan terperinci Corak Pengaturcaraan Meta Runtime dalam Python ini Menarik. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan