你有想象过用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的一些基本特性,包括:
- 基础的html标签
- 组件嵌套
- useState/useEffect/useMemo
可以说如果想只用python写前端,做前后端不分离的页面app,而且是一些极其简单的前端,用reactpy,其实也可以满足你的需求。甚至如果需要调用到原生js模块,也可以考虑参考这个文档去进行。
如果从工业化的角度来说,reactpy距离大规模的前端app还有一定的距离。不仅是因为以nodejs为基础的前端生态非常成熟,而且从开发部署角度来说,reactpy一是开发时期还没有办法做到响应文件变化随时重编译,二是部署前端的方式也不能用纯python,必须要结合nodejs的方式进行。所以如果考虑做复杂的,需要与后端分离的前端应用,reactpy并不是一个选择,现在还只能够作为玩具来玩。