記仇本展示
如題所述,項目已經寫好了,是基於local_storage
存儲在本地的項目
該項目運行時是基於brython
, 你可能想問,為什麼不用原生python
來寫網頁呢,這個有個誤解是,網頁是由html
程式碼寫的,而原生python
想要操作DOM
非常難,所以brython
正是為這個來操作的。
初始開啟頁面,因為沒有資料展示,所以只有一個增加按鈕。
當我們點選【畫個圈圈記下來】按鈕後,會重新整理為新增頁面,例如:
此時,我們只需要輸入訊息,例如記老婆的仇,緣由為買switch遊戲透露給丈母娘,還得被罵。
此時點選記仇,就可以儲存到頁面上了。
此時若點選已原諒,則可以刪除該記錄。
brython 之local_storage
你可能細心發現了,哎,關掉了瀏覽器,下次打開,怎麼還會有記錄在上面呢,這是因為用了 local_storage
,那麼,什麼是local_storage
呢?
哎,我們使用的是brython
中的local_storage
但是,它可不是python
定義的哦,而是HTML 5
提供的儲存資料的API之一,可以在瀏覽器中保持鍵值對資料塊。
現在來展示使用一下brython
儲存和刪除的操作。
導入庫:
from browser.local_storage import storage
儲存數據,例如鍵值資訊juejinName
儲存為pdudo
storage[juejinName] = "pdudo"
查詢的話,直接使用storage[變數]
就好,若為空,則回傳None
v = storage[juejinName]
循環所有的key
,需要引入 window
庫,再使用for...in
來完成
from browser import window for key in window.localStorage: print(key)
也可以直接使用for...in
來遍歷storage
而刪除資料呢?只需要像刪除字典一下
del storage[juejinName]
storage
是不是操作起來跟字典很相似呢?減少了開發者的學習成本。
製作項目
有了上述前置條件後,我們再看該項目,便可以總結為針對localStorage
的增刪查,首先當頁面加載出來的時候,我們需要先遍歷一下localstorage
數據,從而映射為一個table
#,例如:
for key in window.localStorage: tr = html.TR() datas = json.loads(storage[key]) delBtn = html.BUTTON("已原谅") delBtn.dataset["id"] = datas["id"] delBtn.className = "confirm-btn" delBtn.bind("click",delGrudges) td = html.TD(delBtn+" "+time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(int(datas["id"])))) tr <= td for tdVal in datas["whos"],datas["Text"]: td = html.TD(tdVal) tr <= td tb <= tr userWindows <= tb
上述程式碼是遍歷localStorage
,而後在定義刪除按鈕,等將其他值組合完畢後,全部載入進table
#中,而後再頁面上顯示。
而加入資料呢?
def saveGrudges(ev): getWhoVal = document["whos"].value getTextVal = document["textArea"].value if getWhoVal == "" or getTextVal == "": return document["saveBtn"].unbind("click") ids = int(time.time()) datas = { "id": ids, "whos": getWhoVal, "Text": getTextVal } storage[str(ids)] = json.dumps(datas)
上述程式碼,顯示取得input
和textarea
方塊中的值,再判斷是否使用者沒有輸入,我們將資料組裝為字典,而後轉換為字串,再存入localstage
中。
還有其他操作,這個可以直接看程式碼說明,brython
很簡單的。
以上是怎麼用Python寫個有趣的記仇本的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python列表切片的基本語法是list[start:stop:step]。 1.start是包含的第一個元素索引,2.stop是排除的第一個元素索引,3.step決定元素之間的步長。切片不僅用於提取數據,還可以修改和反轉列表。

ListSoutPerformarRaysin:1)DynamicsizicsizingandFrequentInsertions/刪除,2)儲存的二聚體和3)MemoryFeliceFiceForceforseforsparsedata,butmayhaveslightperformancecostsinclentoperations。

toConvertapythonarraytoalist,usEthelist()constructororageneratorexpression.1)intimpthearraymoduleandcreateanArray.2)USELIST(ARR)或[XFORXINARR] to ConconverTittoalist,請考慮performorefformanceandmemoryfformanceandmemoryfformienceforlargedAtasetset。

choosearraysoverlistsinpythonforbetterperformanceandmemoryfliceSpecificScenarios.1)largenumericaldatasets:arraysreducememoryusage.2)績效 - 臨界雜貨:arraysoffersoffersOffersOffersOffersPoostSfoostSforsssfortasssfortaskslikeappensearch orearch.3)testessenforcety:arraysenforce:arraysenforc

在Python中,可以使用for循環、enumerate和列表推導式遍歷列表;在Java中,可以使用傳統for循環和增強for循環遍歷數組。 1.Python列表遍歷方法包括:for循環、enumerate和列表推導式。 2.Java數組遍歷方法包括:傳統for循環和增強for循環。

本文討論了版本3.10中介紹的Python的新“匹配”語句,該語句與其他語言相同。它增強了代碼的可讀性,並為傳統的if-elif-el提供了性能優勢

Python中的功能註釋將元數據添加到函數中,以進行類型檢查,文檔和IDE支持。它們增強了代碼的可讀性,維護,並且在API開發,數據科學和圖書館創建中至關重要。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。