Anvil 提供免費帳戶, 可建立無限制個數的輕流量雲端 App, 但 App 上會有 Anvil 的 Banner, 若要去除 Banner 或擁有完整 Python 功能可付費購買, 分級價目表如下 :
Individual 帳戶每個月要 49 美元有點貴, 若只是小專案或者測試用途, 免費帳戶應該就夠用了.
1. 註冊帳號 :
輸入 E-mail 與登入密碼, 勾選 "Agree to terms" 即可, 它會發出一封確認信到信箱, 按信中的確認連結後馬上就能使用了 :
2. 建立 App :
以所申請之帳號登入 Anvil 後, 按 "Create App" 鈕, 選擇預設之主題樣式 "Material Design" 即可, 點選後會進入 App 設計頁面 : :
此即為所視即所得設計頁面, 左邊是 App 專案設定框, 中間是網頁內容面板, 也就是放置網頁元素的地方, 右邊則是工具箱, 可從工具箱裡直接拖曳網頁元件到中間的版面上.
以建立一個 Say Hello 的 App 為例, 我們需要一個 Label 顯示 "請輸入名字", 一個文字欄位讓使用者輸入名字, 然後一個確定按鈕, 按下去會顯示 "Hello, xxxx".
中間的網頁內容面板上預設已經有一個表單 (Form), 最上方有一個 title 與 link, 分別用來放置 App 的標題與相關超連結 (例如官網網址等). 從右邊工具箱中拖曳一個 Label 元件到上方標題後, 將工具箱往下拉到 "Property" 區, 在 Text 欄位中輸入 "Hello 測試" 作為 App 標題 :
接著依序加入一個內容為 "請輸入名字" 的標籤 (Label), 一個文字欄位 (TexBox), 一個內容設定為 "說哈囉" 的按鈕 (Button), 以及另一個用來顯示結果的標籤 (內容不用設, 要由程式來設定) 如下 :
最後點選 "說哈囉" 按鈕後, 將右側工具箱拉到最後的 "EVENT" 區, 按 "Click" 點選 "self.button_1" 會從 "Design" 模式切到 "Code" 模式, 裡面已定義了一個 button_1_click() 空函數 (內容為 pass) :
將函數內容改為如下 :
def button_1_click(self, **event_args):
"""This method is called when the button is clicked"""
self.label_3.text = "Hello," + self.text_box_1.text
亦即標籤 3 (label_3) 的內容為 "Hello, " 串接文字欄位 (text_box_1) 中所輸入之名字. 這樣就完 App 設計了, 按最上面的 "Run" 鈕即可執行此 App :
按右上角的 "Publish this app" 會產生此 App 的網址以便讓用戶存取 :
按 "Copy" 複製此 App 連結 :
# https://PDEFCXQREVM7EQ65.anvil.app/MK74HFFBOVVWNFVNOSMUVDUM
由於產生的 App 網址不易記憶, 可用短網址服務來做對應 :
# https://lihi1.cc/FDfSI
lihi.io 服務有提供 QR Code 方便手機照相連線 :
關於短網址服務參考 :
# 免費的短網址服務
3. 將 Web app 嵌入網頁中 :
上面建立的 App 可嵌入於網頁的 iframe 框架中, 在 "Publish this app" 發布視窗底下有現成的 Javascript 程式碼與網頁碼 :
<script src="https://anvil.works/embed.js" async></script>
<iframe style="width:100%;" data-anvil-embed src="https://PDEFCXQREVM7EQ65.anvil.app/MK74HFFBOVVWNFVNOSMUVDUM"></iframe>
範例 : 將 Web app 嵌入網頁
<!DOCTYPE html>
<html>
<head>
<title>Javascript 測試</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
</head>
<script src="https://anvil.works/embed.js" async></script>
<body>
<iframe style="width:100%;" data-anvil-embed src="https://PDEFCXQREVM7EQ65.anvil.app/MK74HFFBOVVWNFVNOSMUVDUM"></iframe>
</body>
</html>
這是在手機測試的結果, 還不錯.
參考 :
# https://anvil.works/learn/tutorials/hello-world
沒有留言 :
張貼留言