Pyscript,创建一个能执行crud操作的网页应用

目录

实现一个添加邀请客人名单的功能
循序渐进,逐步实现:

  1. 输入客人名称,按下enter键添加客人名单
  2. 点击客人名单在名单上添加或者取消添加删除线,表示已经检查客人到场或未到场
  • checkbox,点击客人名单或者点击checkbox,则勾选或取消勾选名单,与删除线效果同步渲染
  • 添加一个按钮,让用户点击按钮可以添加客人
  1. 编写Python代码使用pyscript的PyItemTemplate的render_content()修改渲染到页面上字体的样式,而不是默认的样式

输入客人名称到inputbox,按enter键添加客人名单

编写HTML head部分代码

head引用最新的pyscript css和js脚本
添加py-register-widget标签,取一个名称py-contactlist作为等会要使用的pyscript标签名,这个标签可以直接引用py-register-widget中关联的python插件脚本

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><link rel="stylesheet" href="https://pyscript.net/latest/pyscript.css"><script defer src="https://pyscript.net/latest/pyscript.js"></script><py-register-widget src="./pylist.py" name="py-contactlist"></py-register-widget><title>Guest book</title>
</head>

注:由于版本更新迭代频繁,引用的源路径可能有变化,如果出现报错,可在github pyscript源码查看更新的示例example(目前没有相关的文档)

PyItem和PyList定义前端item和list的各种操作

观察pyscript在github的源码,确定要如何编写继承的类
在这里插入图片描述

# -*- coding:utf-8 -*-
from datetime import datetimeclass PyItem(PyItemTemplate):passclass PyList(PyListTemplate):item_class = PyItemdef add(self, item):if isinstance(item, str):item = {"content": item, "created_at": datetime.now()}# labels是展示的名称return super().add(item, labels=["content"])

其中PyItemTemplatePyListTemplate是本次要使用的pyscript类,主要内容是对前端item和list的操作
这里没有导入会IDE抛红,不过不需要理会,这些类方法只会在HTML中执行
PyList中指明item_class为继承的PyItem
重写一下PyListTemplate的add方法,定义要从前端输入接收的item,并定义创建时间created_ad,再渲染返回到前端之前,add方法中的这些数据都可能会再用到
pylist
在py-register-widget添加 klass="PyList"指明引用的Python pyscript类

<py-register-widget src="./pylist.py" name="py-contactlist" klass="PyList"></py-register-widget>

注意这里关键字名称是klass而不是class,为了避免和html保留的class关键字冲突

编写HTML body部分代码

<body style="margin: 5% 10%"><h2>Guest book with PyScript📖</h2><br><div style="width: 80%"><py-inputbox id="new-entry">def on_keypress(e):if e.code == "Enter":add_contact()</py-inputbox><py-contactlist id="guestBook"></py-contactlist></div><py-script>def add_contact():# new_entry用法与前面的id="new-entry"有关,在Python中命名使用下划线连接# datetime是在引用的pylist.py中导入了,所以不需要再导入guest = {"content": new_entry.value, "created_at": datetime.now()}# 这里的add方法来自于PyList中的add方法guestBook.add(guest)# 清除inputbox中的内容new_entry.clear()</py-script>
</body>

创建py-inputbox的pyscript标签,定义on_keypress方法捕获在键盘"Enter"被按下之后,执行一些操作:
定义add_contact方法,向py-contactlist标签执行添加客人名单的操作,这里的py-contactlist和前面py-register-widget中的name保持一致
于是可以达到如下的效果,输入名单之后按enter键可添加名单
在这里插入图片描述

点击客人名单在名单上添加或者取消添加删除线,表示客人已经check到场或未check

首先为item对象添加一个deleted属性,代表是否执行删除(是否已经check)
编写python代码实现on_click事件操作,添加删除线或取消删除线,表示已经check
需要在PyItem中重写PyItemTemplate的on_click方法

class PyItem(PyItemTemplate):def on_click(self, evt=None):# 点击人物名称,删除或者取消删除已经签到的人# 这里如果没有deleted键,前端会有报错self.data["deleted"] = not self.data["deleted"]# 如果deleted就添加删除线,否则移除删除线self.strike(self.data["deleted"])

添加名单的时候,默认传入deleted为False

    <py-script>def add_contact():# new_entry用法与前面的id="new-entry"有关,在Python中命名使用下划线连接# datetime是在引用的pylist.py中导入了,所以不需要再导入guest = {"content": new_entry.value, "created_at": datetime.now(), "deleted": False}# 这里的add方法来自于PyList中的add方法guestBook.add(guest)# 清除inputbox中的内容new_entry.clear()</py-script>

效果:
在这里插入图片描述

点击checkbox中的勾选,也同步执行添加删除线或取消删除线

在PyItem中选择输入的element将其checked属性的值修改为和deleted相同的布尔值,这实际上等价执行了js的document.querySelector的相关方法

class PyItem(PyItemTemplate):def on_click(self, evt=None):# 点击人物名称,删除或者取消删除已经签到的人# 这里如果没有deleted键,前端会有报错self.data["deleted"] = not self.data["deleted"]# 如果deleted就添加删除线,否则移除删除线self.strike(self.data["deleted"])# 点击人物名称添加删除线,同时checked(打勾)也要勾选或者取消勾选self.select("input").element.checked = self.data["deleted"]

效果:
在这里插入图片描述

同时再添加一个按钮支持鼠标点击这按钮添加客人名单

在HTML中py-inputbox标签同级添加一个py-button标签并定义一个on_click点击按钮的事件,当点击这个按钮时就执行添加名单的操作

    <div style="width: 80%"><py-inputbox id="new-entry">def on_keypress(e):if e.code == "Enter":add_contact()</py-inputbox><br><br><py-button id="new-guest-btn" label="Add guest">def on_click(e):add_contact()</py-button><py-contactlist id="guestBook"></py-contactlist></div>

效果:
在这里插入图片描述

修改渲染到页面上字体的样式代替默认的样式

查看源码可知PyItemTemplaterender_content只是将各个label使用"-"连接起来,样式使用了pyscript默认的样式
覆写PyItemTemplaterender_content方法,增加一个标签,将content标签改为name和email,将这两个label使用符号📙连起来展示
然后再添加一个邀请时间,用较小的字体展示

最后完整的代码:
pylist.py

# -*- coding:utf-8 -*-
from datetime import datetimeclass PyItem(PyItemTemplate):def on_click(self, evt=None):# 点击人物名称,删除或者取消删除已经签到的人# 这里如果没有deleted键,前端会有报错self.data["deleted"] = not self.data["deleted"]# 如果deleted就添加删除线,否则移除删除线self.strike(self.data["deleted"])# 点击人物名称添加删除线,同时checked(打勾)也要勾选或者取消勾选self.select("input").element.checked = self.data["deleted"]def render_content(self):s = "📙".join([self.data[f] for f in self.labels])create_at = self.data["created_at"].strftime("%F %X")return s + "<br/>" f"<small class='timestamp'>⌚invited at: {create_at}</small>"class PyList(PyListTemplate):item_class = PyItemdef add(self, item):if isinstance(item, str):name, email = [x.strip() for x in item.split(",")]item = {"name": item, "email": email, "created_at": datetime.now(), "deleted": False}# labels是展示的名称return super().add(item, labels=["name", "email"])

add_contact添加客人名单时也将一个标签content改为两个name和email,输入时用逗号(“,”)隔开
guestbook.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><link rel="stylesheet" href="https://pyscript.net/latest/pyscript.css"><script defer src="https://pyscript.net/latest/pyscript.js"></script><py-register-widget src="./pylist.py" name="py-contactlist" klass="PyList"></py-register-widget><title>Guest book</title>
</head>
<body style="margin: 5% 10%"><h2>Guest book with PyScript📖</h2><p>You can use <code>ENTER</code> to insert a guest book entry.</p><p>Paste <code style="background: #eee; padding: 0.5%">Pam Beesly, pam@dundermifflin.com</code> to insert the guest name and email.</p><br><div style="width: 80%"><py-inputbox id="new-entry">def on_keypress(e):if e.code == "Enter":add_contact()</py-inputbox><br><br><py-button id="new-guest-btn" label="Add guest">def on_click(e):add_contact()</py-button><py-contactlist id="guestBook"></py-contactlist></div><py-script>def add_contact():name, email = [x.strip() for x in new_entry.value.split(",")]# new_entry用法与前面的id="new-entry"有关# datetime是在引用的pylist.py中导入了,所以不需要再导入guest = {"name": name, "email": email, "created_at": datetime.now(), "deleted": False}# 这里的add方法来自于PyList中的add方法guestBook.add(guest)# 清除inputbox中的内容new_entry.clear()</py-script>
</body>
</html>

最终效果展示:

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/469390.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

爬虫实战学习笔记_1 爬虫基础+HTTP原理

1 爬虫简介 网络爬虫&#xff08;又被称作网络蜘蛛、网络机器人&#xff0c;在某些社区中也经常被称为网页追逐者)可以按照指定的规则&#xff08;网络爬虫的算法&#xff09;自动浏览或抓取网络中的信息。 1.1 Web网页存在方式 表层网页指的是不需要提交表单&#xff0c;使…

LeetCode | HouseCode 算法题

题目&#xff1a; You are a professional robber planning to rob houses along a street. Each house has a certain amount of money stashed, the only constraint stopping you from robbing each of them is that adjacent houses have security system connected and it…

爬虫实战学习笔记_2 网络请求urllib模块+设置请求头+Cookie+模拟登陆

1 urllib模块 1.1 urllib模块简介 Python3中将urib与urllib2模块的功能组合&#xff0c;并且命名为urllib。Python3中的urllib模块中包含多个功能的子模块&#xff0c;具体内容如下。 urllib.request&#xff1a;用于实现基本HTTP请求的模块。urlb.error&#xff1a;异常处理…

Python解决多个进程服务重复运行定时任务的问题

记录多实例服务定时任务出现运行多次的问题 问题&#xff1a;web项目运行多个实例时&#xff0c;定时任务会被执行多次的问题 举例来说 我使用库APScheduler排定了一个定时任务taskA在每天的晚上9点需要执行一次&#xff0c;我的web服务使用分布式运行了8个实例&#xff0c;于…

java----IO和NIO的区别

概念&#xff1a;NIO即New IO&#xff0c;这个库是在JDK1.4中才引入的。NIO和IO有相同的作用和目的&#xff0c;但实现方式不同&#xff0c;NIO主要用到的是块&#xff0c;所以NIO的效率要比IO高很多。在Java API中提供了两套NIO&#xff0c;一套是针对标准输入输出NIO&#xf…

【Pytorch神经网络理论篇】 11 卷积网络模型+Sobel算子原理

同学你好&#xff01;本文章于2021年末编写&#xff0c;已与实际存在较大的偏差&#xff01; 故在2022年末对本系列进行填充与更新&#xff0c;欢迎大家订阅最新的专栏&#xff0c;获取基于Pytorch1.10版本的理论代码(2023版)实现&#xff0c; Pytorch深度学习理论篇(2023版)…

ubuntu 14.04中文显示乱码问题

乱码显示如下&#xff1a; [<E9><97><AE><E9><A2><98><E6><8F><8F><E8><BF><B0>]:<E5><A2><9E><E5><8A><A0>tm100<E9><A1><B9><E7><…

DataFrame高效处理行列数据/倒三角型数据/处理阶梯型数据/根据列的值确定行的值

锲子 在使用pandas处理数据时&#xff0c;遇到了一种要按照留存天数来处理的数据&#xff0c;当列所对应的日期超过了最晚的“今天”那么数据就要置为0&#xff0c;举个例子&#xff1a; 在这个DataFrame中&#xff0c;需要将超过了今天2022-10-30的数据置为“-”&#xff0c…

转载 ---资深HR告诉你:我如何筛选简历与选择人员的

资深HR告诉你&#xff1a;我如何筛选简历与选择人员的 有个公司HR看简历 先直接丢掉一半 理由是不要运气不好的应聘者。 当然这可能只是某些HR面对太多的简历产生了偷懒的情绪&#xff0c;但是不论是Manager&#xff0c;亦或是Team Leader&#xff0c;都会遇到招聘的问题&#…

爬虫实战学习笔记_3 网络请求urllib模块:设置IP代理+处理请求异常+解析URL+解码+编码+组合URL+URL连接

1 设置IP代理 1.1 方法论述 使用urllib模块设置代理IP是比较简单的&#xff0c;首先需要创建ProxyHandler对象&#xff0c;其参数为字典类型的代理IP&#xff0c;键名为协议类型&#xff08;如HTTP或者HTTPS)&#xff0c;值为代理链接。然后利用ProxyHandler对象与buildopene…

vim 插件cscope 使用

&#xff11;&#xff0e;安装 sudo apt-get install cscope &#xff12;&#xff0e;初始化 cscope -Rbq 你想在哪个目录下面用这个功能&#xff0c;就在哪个目录下面运行这个命令 &#xff13;&#xff0e;vim kpd.c &#xff14;&#xff0e;输入 :cs add cscope.o…

Sanic服务启动失败,报错Cannot finalize with no routes defined

Sanic服务启动失败&#xff0c;记录解决方法 问题描述 Sanic服务启动失败&#xff0c;同样的代码和python版本在之前的win10系统上运行的好好的&#xff0c;换了台win11的机器就跑不起来了&#xff0c;不知道是系统原因还是因为换了执行pycharm等其他原因 在尝试启动时总是会…

打一波鸡血

在朋友圈看的一首诗&#xff0c;觉得很励志&#xff0c;如下&#xff1a;问题在于过度担心未来总是埋怨现在不断惋惜过往内心不知足想法逾现实行动很迟缓时间可贵青春难再审视脚下的路充实度日一日尚短庸碌混迹一日便长无妄的借口只会难上加难脚踏实地走才能遇难成祥守住时光用…

【Pytorch神经网络理论篇】 12 卷积神经网络实现+卷积计算的图解

同学你好&#xff01;本文章于2021年末编写&#xff0c;获得广泛的好评&#xff01; 故在2022年末对本系列进行填充与更新&#xff0c;欢迎大家订阅最新的专栏&#xff0c;获取基于Pytorch1.10版本的理论代码(2023版)实现&#xff0c; Pytorch深度学习理论篇(2023版)目录地址…

vim 函数列表插件

&#xff11;&#xff0e;apt-get install exuberant-ctags &#xff12;&#xff0e;unzip taglist_42.zip  把解压出来的文件放到 /home/weiqifa(自己的用户名)/.vim/  资源下载&#xff1a; http://download.csdn.net/detail/weiqifa0/9137283&#xff13;&#xff0e;s…

【Pytorch神经网络实战案例】09 使用卷积提取图片的轮廓信息(手动模拟Sobel算子)

1 载入图片并显示 import matplotlib.pyplot as plt import matplotlib.image as mpimg import torch import torchvision.transforms as transforms import os os.environ["KMP_DUPLICATE_LIB_OK"]"TRUE" ### 1 载入图片并显示 myimg mpimg.imread(img.…

jquery深入学习

的转载于:https://www.cnblogs.com/lizhiwei8/p/6417798.html

【Pytorch神经网络理论篇】 13 深层卷积神经网络介绍+池化操作+深层卷积神经网络实战

同学你好&#xff01;本文章于2021年末编写&#xff0c;获得广泛的好评&#xff01; 故在2022年末对本系列进行填充与更新&#xff0c;欢迎大家订阅最新的专栏&#xff0c;获取基于Pytorch1.10版本的理论代码(2023版)实现&#xff0c; Pytorch深度学习理论篇(2023版)目录地址…

gulp 系统教程

移步: http://www.cnblogs.com/2050/p/4198792.html gulp外挂 加md5 版本号 自动合并图片并修改css的坐标 一个系统列子 gulp可以做哪些事情转载于:https://www.cnblogs.com/dhsz/p/6419383.html

Android 广播接收

问题&#xff1a;写了一个应用来验证我按下音量键时发送出来的广播&#xff0c;可是老是提示出错&#xff0c; 原因&#xff1a;我的整个应用只继承吧BroadcastReceive&#xff0c;没有实际的继承Activity所以总是出现各种问题&#xff0c;现在修改好&#xff0c;上传代码 http…