django-components v 模板现在与 Vue 或 React 相当

django-components v 模板现在与 vue 或 react 相当

嘿,我是 juro,我是 django-components 的维护者之一。在 v0.90-0.94 版本中,我们添加了一些功能,使在模板中使用组件更加灵活,类似于 jsx / vue

(此信息已经有点过时了(一个月前发布;最新的是 v0.101),因为我正忙于添加对 js / css 变量、typescript 和 sass 以及 html 片段的支持。令人兴奋的东西!但我意识到还没有分享此更新!)

无论如何,以下是一个 blog_post 组件,它接受从 blog_post_props 应用的标题、id 和附加 kwargs:

    {% blog_post      title="{{ person.first_name }} {{ person.last_name }}"      id="{% random_int 10 20 %}"      ...blog_post_props    / %}

以上是多个特征的组合:

1。自关闭标签:

立即学习“前端免费学习笔记(深入)”;

而不是

    {% component "my_component" %}    {% endcomponent %}

您现在可以简单地写

    {% component "my_component" / %}

2。多行标签:

django_components 现在自动配置 django 以允许多行标签。因此,不要将所有内容都塞在一行中:

    {% component "blog_post" title="abcdef..." author="john wick" date_published="2024-08-28" %}    {% endcomponent %}

您可以将其分散到多行中:

    {% component "blog_post"      title="abcdef..."      author="john wick"      date_published="2024-08-28"    / %}

3。展开运算符:

类似于 jsx 中的 …props 运算符或 vue 中的 v-bind,这会将 props / kwargs 插入给定位置。

所以而不是

    {% component "blog_post"      title="abcdef..."      author="john wick"      date_published="2024-08-28"    / %}

你可以将 kwargs 放入字典中,然后应用它:

    # python    props = {        "title": "abcdef...",        "author": "john wick",        "date_published": "2024-08-28"    }
    {# django #}    {% component "blog_post" ...props %}

4。组件输入中字符串文字内的模板标签:

您现在可以在组件输入中使用模板标签和过滤器:

    {% component 'blog_post'      "as positional arg {# yay #}"      title="{{ person.first_name }} {{ person.last_name }}"      id="{% random_int 10 20 %}"      readonly="{{ editable|not }}"    / %}

这样您就不必每次需要格式化值时都定义额外的变量。

请注意,当只有一个标签并且周围没有额外的文本时,结果将作为值传递。所以“{% random_int 10 20 %}”传递一个数字,“{{ editable|not }}”传递一个布尔值。

您甚至可以更进一步,获得与 vue 或 react 类似的体验,您可以在其中评估任意代码表达式,又名类似于:

    

这可以通过 django-expr 实现,它添加了一个 expr 标签和过滤器,您可以使用它来计算模板中的 python 表达式:

    {% component "my_form"      value="{% expr 'input_value if is_enabled else none' %}"    / %}

5。支持 {% comp_name %} {% endcomp_name %} 和 tagformatter

默认情况下,组件是使用组件标签编写的,后跟组件的名称:

    {% component "button" href="..." disabled %}        click me!    {% endcomponent %}

您现在可以更改此设置(甚至可以自己制作!)。

例如,将 components.tag_formatter 设置为“django_components.shorthand_component_formatter”允许您编写如下组件:

    {% button href="..." disabled %}        Click me!    {% endbutton %}

还有更多功能即将推出,所以一定要尝试一下 django-components!

以上就是django-components v 模板现在与 Vue 或 React 相当的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1350008.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 13:52:49
下一篇 2025年12月13日 13:53:03

相关推荐

  • Python 装饰器:简化代码

    python 中的装饰器是一个强大的工具,允许您修改函数或方法的行为,而无需更改其源代码。它们提供了一种添加功能的简洁方法,并广泛用于日志记录、执行规则和优化性能。 在这篇文章中,我们将通过简单的示例来了解六种常见的 python 装饰器。 1 – @staticmethod: 定义静态…

    好文分享 2025年12月13日
    000
  • 如何启动 Flask 应用程序:综合指南

    如果您像我一样,您可能已经见过几种启动 flask 应用程序的不同方法,并且想知道哪一种是最好的。有时,您会遇到manage.py,有时,您会看到create_app。这可能会导致混乱,特别是如果您是 flask 开发新手或从一个项目过渡到另一个项目时。 在本文中,我将引导您了解启动 flask 应…

    2025年12月13日
    000
  • python 小数模块

    编程语言有各种类型的数据来处理数字信息。整数(int)、实数(float)类型和python支持其他类型,例如分数和复数。 然而,今天我想谈谈十进制类型。浮点或浮点有几个精度问题,这些问题在某些类型的应用程序中是无法容忍的,例如与金融有关的应用程序。 让我们看一个非常简单的案例: from deci…

    2025年12月13日
    000
  • 在 Python 中处理 PDF 和 Word 文档

    简介 (https://nearlearn.com/python-classroom-training-institute-bangalore)在 Python 中处理 PDF 和 Word 文档可以使用多个库来完成,每个库都针对特定任务(例如读取、写入和操作这些文件格式)进行定制。班加罗尔的 Py…

    2025年12月13日
    000
  • Python 第 00 天

    今天,我开始了我的个人挑战#100DaysOfCode。为了这个挑战,我选择学习Python,因为我的目标是成为一名数据分析师。 第 2 章: 变量和字符串 我用来学习 Python 的材料是 Eric Matthes 写的一本名为《Python Crash Course》的书。它对学习非常有帮助,…

    2025年12月13日
    000
  • 使用流下载处理大文件下载,以避免超时和其他响应错误

    在 web 应用程序中处理大文件下载时,开发人员面临的常见问题之一是超时、响应时间、内存过载错误。大多数网络服务器和客户端对等待响应的时间都有限制,如果下载过程花费太长时间,您可能会遇到这些错误。为了缓解这一问题,流式下载是一种更高效且可扩展的解决方案。 在本文中,我们将探讨如何使用 python …

    2025年12月13日
    000
  • 使用Python制作Spotify歌曲下载器(mp3)

    作者:特里克斯·赛勒斯 为什么使用 python 下载 spotify 曲目? 用于离线收听。以 mp3 格式保存您最喜欢的曲目。用于创建个人音乐收藏。~ 使用 python,下载 spotify 曲目成为一项简单的自动化任务。 让我们开始吧!第1步:安装spotdl 首先,您需要安装 spotdl…

    2025年12月13日
    000
  • 决策和重复循环:初学者的基本指南

    编程本质上是教计算机做出决定并重复操作。这是通过控制结构来完成的,控制结构是任何编程语言的基础。在本文中,我们将通过实际示例探讨决策循环和重复循环的主要概念。 决策循环 决策循环,也称为条件结构,允许程序根据某些条件选择不同的路径。这里的主要概念是检查条件是真还是假。 如果,否则如果,否则 最常见的…

    2025年12月13日
    000
  • Hacktoberfest:AnadiCSV 项目

    大家好,我编写了一个名为 AnadiCSV 的工具,它允许您对 CSV 文件使用 SQL 查询。 。 这个工具是用 Python 编写的,使用 Textual 作为 UI 库和 DuckDB 来处理 CSV 数据,目前适用于 Docker 容器。我认为这个项目可以成为参加 Hacktoberfest…

    2025年12月13日
    000
  • 使用 Sheepy 在 Python 中进行单元测试

    大家好,今天我来给大家介绍一个新的单元测试库,叫做sheepy,但是首先我们来谈谈单元测试的重要性。该库不适合初学者,要使用它进行单元测试,您需要额外注意。它仅具有用于使用端点和 http 错误检查模块进行 api 测试的断言。 github链接:githubpypi 链接:pypi 生产中所有成熟…

    2025年12月13日
    000
  • 机器学习中的 C++:逃离 Python 和 GIL

    介绍 当 #%#$#%@%@%$#%$#%#%#$%@_23eeeb4347bdd26bfc++6b7ee9a3b755dd 的全局解释器锁 (gil) 成为需要高并发或原始性能的机器学习应用程序的瓶颈时,c++ 提供了一个引人注目的替代方案。这篇博文探讨了如何利用 c++ 进行机器学习,重点关注性…

    2025年12月13日
    000
  • 如何使用 Python 降低歌曲的音调

    如果您曾经想改变歌曲的音调而不改变其速度,那么这篇博文适合您。变调是音乐家、dj 和音频工程师的常见任务。在本教程中,我们将探索如何使用 python 和 pydub 库降低歌曲的音调,并将此过程自动应用于文件夹中的多首歌曲。 为什么要进行变调? 在音乐中,变调意味着改变歌曲的音调(升高或降低)而不…

    2025年12月13日
    000
  • python社区版和专业版区别

    Python 社区版和专业版的主要区别在于付费与免费。社区版适用于个人开发者、初学者和非营利组织,免费提供基本功能和社区支持。专业版适用于企业和组织,需要付费订阅,提供高级功能、技术支持和云部署选项。 Python 社区版和专业版之间的区别 主要区别: 主要区别在于付费与免费。 详细区别: 立即学习…

    2025年12月13日
    000
  • python社区版可以开发软件吗

    是,Python 社区版(CPython)可用于软件开发,因为它包含了必要的工具和库,包括核心解释器、标准库、各种工具和实用程序。它广泛用于开发网络应用程序、桌面应用程序、数据科学和机器学习项目,以及脚本和自动化任务。此外,它还提供了广泛的第三方库,扩展了其软件开发能力。 Python 社区版是否可…

    2025年12月13日
    000
  • python怎么下载手机版

    可以通过 Python 下载手机应用:导入 os 和 requests 模块。获取要下载的应用链接。发送下载请求。检查响应状态代码。保存下载的应用。使用系统命令安装下载的应用(确保启用 USB 调试)。 如何通过 Python 下载手机应用 Python 是一种高级编程语言,可用于执行各种任务,包括…

    2025年12月13日
    000
  • python最新版本下载教程

    Python 最新版本可通过以下步骤下载:访问 Python 官网:https://www.python.org/根据操作系统选择安装程序运行安装程序验证安装(命令:python –version) Python 最新版本下载教程 引言Python 是目前最流行的编程语言之一,广泛应用于…

    2025年12月13日
    000
  • python下载视频源代码

    使用 Python 下载视频的方法:安装 requests 和 beautifulsoup4 库。确定要下载的视频的 URL。使用 requests 库发送 HTTP 请求并使用 BeautifulSoup 解析响应以提取视频来源。使用 requests 库再次发送请求以获取视频数据并写入本地文件。…

    2025年12月13日
    000
  • pycharm用社区版可以吗

    对于大多数 Python 开发人员来说,PyCharm 社区版足够满足其需求,它提供代码编辑、调试、测试、版本控制集成和可扩展性等核心功能。但是,它缺乏项目管理、数据库工具、远程开发和专业版中提供的其他高级功能。 PyCharm 社区版是否够用? 简介PyCharm 是一种流行的 Python 集成…

    2025年12月13日
    000
  • python3.9.2下载教程

    Python 3.9.2 下载步骤:访问官网下载页面:https://www.python.org/downloads/选择操作系统,下载对应安装程序安装 Python,按照提示完成操作 Python 3.9.2 下载教程 下载步骤: 访问官方下载页面:前往 Python 官网下载页面:https:…

    2025年12月13日
    000
  • python模拟电脑操作

    Python可模拟电脑操作,包括:鼠标移动:使用pyautogui库的moveTo和click方法。键盘输入:使用keyboard库的write、press和release方法。文件管理:使用os模块的exists、listdir、mkdir和remove函数。 Python 模拟电脑操作 导言 P…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信