專案名稱 : Geo Memoir 旅遊經驗分享平台
專案簡介
此作品使用於:此平台提供給旅遊愛好者,分享旅途上所拍攝的照片,以及旅途中的故事,網站提供英、繁、簡三種語言切換
製作動機
為什麼會想製作這個主題:和身邊國內外朋友交流時,很常提到彼此國家推薦的旅遊景點或美食等,因此想藉由這個機會製作一個旅遊經驗分享平台,無論是在國內或是國外旅遊,都可分享在平台上,同時也可針對感興趣的旅遊故事進行留言討論
專案主架構
data:image/s3,"s3://crabby-images/01bfe/01bfe27f9b7c7a6fa697bd818204d44edf653708" alt=""
前端
data:image/s3,"s3://crabby-images/75cf2/75cf20bccbbfcd6df4631863f260850d3ea9a7ff" alt=""
Ø Bootstrap 排版
1.container/container-fluid
2.grid system
3.flexbox
data:image/s3,"s3://crabby-images/a36c7/a36c79c68e1cf2058b6bcb09c59fe276f5a2c3c6" alt=""
Ø Bootstrap 元素、物件
1.Navbar 導航欄
2.Carousel 輪播圖
data:image/s3,"s3://crabby-images/3b117/3b11724b77605560da599dbd61cadf6654d2a2c5" alt=""
data:image/s3,"s3://crabby-images/037db/037dbe3a0daaea491b921be4bcf0da8fbe5addcc" alt=""
Ø Bootstrap 元素、物件
3.Buttons 按鈕
4.Pagination 分頁
data:image/s3,"s3://crabby-images/7703d/7703dd69be3f370459ea4d66c8ad8db271feb539" alt=""
data:image/s3,"s3://crabby-images/598bb/598bb1a6cf895479d97ccec38d88e626372cc1d4" alt=""
data:image/s3,"s3://crabby-images/b0de9/b0de9a5fdf09a9c38b508e2fd3e630392f9e16c0" alt=""
Ø Blueprint
1.路徑的部分使用了Blueprint套件, 在每個url前加上語言前綴, 將當前語言存儲在全局變量g中
2.從用戶端 Accept-Language取偏好語言, 若無該語言則取配置文件中首位
data:image/s3,"s3://crabby-images/3fa20/3fa20bb3b6dafe9cb92991bbd55922303d2e164a" alt=""
data:image/s3,"s3://crabby-images/be5fa/be5fa00268b459c2fa59e11c3b09fbcc16547e21" alt=""
Ø Flask-Babel 翻譯
1.pybabel extract –F babel.cfg –o messages.pot .
(建立/更新翻譯模板)
2.pybabel init –i messages.pot –d app/translations –l lang (建立語系) pybabel update –i messages.pot –d app/translations
(更新翻譯檔案)
3.pybabel compile –d app/translations
(編譯翻譯檔案)
data:image/s3,"s3://crabby-images/9d0c0/9d0c0cc838945b0aad4a35dc3039c6cf879d2b39" alt=""
Ø Google Sign-In
data:image/s3,"s3://crabby-images/c84b4/c84b45c85fcc78b27834f8e4eb17bfbfe9770cb6" alt=""
data:image/s3,"s3://crabby-images/c0d2e/c0d2ec4ef17be309d77fb02ea0f6502cff477134" alt=""
Luxon library – Javascript
Ø 處理各地日期、時間
data:image/s3,"s3://crabby-images/a12a2/a12a29dba82d6187e20a6673180948e4ffd36b12" alt=""
data:image/s3,"s3://crabby-images/36afd/36afd929a935728ca6639193881912205ac72eab" alt=""
後端
data:image/s3,"s3://crabby-images/5739f/5739f2b4ab9e7b84335cc113dbee5b125da35ab8" alt=""
Ø 藉由後端判斷登錄方式, 傳送資料給前端做會員登錄顯示
data:image/s3,"s3://crabby-images/203eb/203eb60406211feb40af345a6926f8b33ed7abdb" alt=""
Ø 除了會員登錄顯示, 同時做會員區選項href的拼接和附值
data:image/s3,"s3://crabby-images/d7b14/d7b1402017c0297c6cb27b19b85159c18ece8f82" alt=""
Ø 分頁
在後端建立custom_paginator方法, 將分頁的判斷數據以及當前頁面資料等返回給前端
data:image/s3,"s3://crabby-images/1c780/1c78024120eafb85030bffb9a03376ebeaf246d5" alt=""
data:image/s3,"s3://crabby-images/7579d/7579d098be5256b88fe9efa1f91570ba296fe8b3" alt=""
Ø 翻譯
1.django-admin makemessages –all django-admin compilemessages
2. 創建截取語言前綴以及翻譯方法, 於views.py中引用, 將需要response按照當前對應的語言做翻譯再行返回
data:image/s3,"s3://crabby-images/855ca/855ca8cd3666e8614261cd778dce79008b87f127" alt=""
data:image/s3,"s3://crabby-images/954b3/954b38db3d7e6e74fa7d6fc8b6cb35f4d9f81f4d" alt=""
Ø 設置crontab工作排程 > 每小時更新一次天氣訊息
data:image/s3,"s3://crabby-images/886db/886db0582095e912aed20632258e9557559ecff3" alt=""
Ø 郵件發送 - Celery
data:image/s3,"s3://crabby-images/52ce8/52ce802d78a469eb8fae42b7385245620afa223d" alt=""
data:image/s3,"s3://crabby-images/3d844/3d844053c991db41b67abf1ca5c70078b8a89793" alt=""
data:image/s3,"s3://crabby-images/1f07b/1f07b55b7390eb95806e4ba1773027b4f9c06fac" alt=""
data:image/s3,"s3://crabby-images/ab004/ab00481817428f63781c4d4529140530a2af7d60" alt=""
專案心得
本次的網站製作是我的第一個作品, 所以在規劃方面花了一點時間, 製作期間我發現許多前端所需的功能在課程中並未提到, 所以需要額外去做很多功課才能完成。
為了讓網站更好的呈現, 後續我也添加了不同功能並做了修改, 光是首頁的一個小部分就改了無數次, 印象最深刻的還是架網站的部分, 因為需要為購買的域名作設定, nginx以及AWS的部分前後出現了許多問題, 後端數據始終無法出來, 花了非常久的時間才終於將所有問題排除。
透過這一次的經驗, 我知道如何更好的去整合前後端, 也知道如何更快的去排查問題, 在架網站的部分也學習到了很多額外的知識, 能夠好好的運用在下一次的網站製作。
目前我已完成Python第四階段的學習, 後續將持續向第五階段邁進, 並同時增進網站製作的能力。
Comentários