赞
踩
你有想象过用python来写web前端这种操作么?近期在github-trending上就有这样的一个项目reactpy,可以满足你在python上写web前端的欲望。为此,笔者也决定踩踩坑,看看这个项目的形式到底如何,能不能很方便地实际投产。
要用到这个项目,除了reactpy库本身外,还需要一个backend-implementation来部署前端开发环境到本地端口。这里我们采取的操作是pip install reactpy[fastapi]
,这样就能直接安装上以fastapi为后端实现的前端开发环境部署。
要开始写一个简单的网页,可以参考reactpy的官方网站。基本代码如下:
import reactpy from reactpy import component, html, run @component def reactpy_content(count): add_count, set_add_count = reactpy.use_state(1) multi_count = reactpy.use_memo(lambda: count * 3, [count]) reactpy.use_effect(lambda: set_add_count(add_count + multi_count), [multi_count]) return html.div( { 'style': {'color': '#ff0000'} }, html.ol( html.li(f'count: {count}'), html.li(f'multi_count: {multi_count}'), html.li(f'add_count: {add_count}') ), ) @component def reactpy_app(): count, set_count = reactpy.use_state(0) return html.div( html.h1('Debug Site'), html.button({ 'on_click': lambda e: set_count(count + 1) }, "Increment Count"), reactpy_content(count) ) if __name__ == "__main__": run( reactpy_app, host='127.0.0.1', port=7654 )
展现出来的效果是:
可以看到这个案例里面,我们能够模拟到react的一些基本特性,包括:
可以说如果想只用python写前端,做前后端不分离的页面app,而且是一些极其简单的前端,用reactpy,其实也可以满足你的需求。甚至如果需要调用到原生js模块,也可以考虑参考这个文档去进行。
如果从工业化的角度来说,reactpy距离大规模的前端app还有一定的距离。不仅是因为以nodejs为基础的前端生态非常成熟,而且从开发部署角度来说,reactpy一是开发时期还没有办法做到响应文件变化随时重编译,二是部署前端的方式也不能用纯python,必须要结合nodejs的方式进行。所以如果考虑做复杂的,需要与后端分离的前端应用,reactpy并不是一个选择,现在还只能够作为玩具来玩。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。