[{"data":1,"prerenderedAt":1322},["ShallowReactive",2],{"tag-threads-zh-TW-Food":3,"latest-articles-zh-TW":868,"author-context":1260},[4,49,79,151,219,564,594,644,748,772,822],{"id":5,"title":6,"animated":7,"body":8,"client":34,"cover":34,"css_code":34,"description":31,"extension":35,"html_code":34,"images":36,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":38,"navigation":37,"order":34,"path":39,"photos":40,"published_at":41,"reading_time":34,"related":34,"role":34,"seo":42,"slug":43,"source_hash":34,"status":34,"stem":44,"summary":45,"tags":46,"tech_stack":34,"translation_of":34,"type":47,"url":34,"video_url":34,"__hash__":48},"threads/threads/pages/about.md","關於我",false,{"type":9,"value":10,"toc":30},"minimark",[11,18,21,24,27],[12,13,14],"blockquote",{},[15,16,17],"p",{},"Boys, be ambitious!",[15,19,20],{},"一個從面板業轉職的網頁工程師。大半時間寫著給機器看的語言，在這裡寫給人類看的文字。",[15,22,23],{},"著迷於所有使用有限的素材，卻能留下偉大遺產的事情。例如音樂與文字。當然，還有程式碼。",[15,25,26],{},"而鍵盤就像是 21 世紀的元素週期表。不論是工程師或是作家，我們所擁有的僅僅是眼前的 26 個英文字母、以及一些符號，但是我們卻有機會創造出全世界都在使用的產品。改變人們生活的樣貌、或是留下偉大的想法。",[15,28,29],{},"在 AI 氾濫的時代，我要用剛剛好的 Tech Stack，開發實用的生活小物 SaaS。",{"title":31,"searchDepth":32,"depth":32,"links":33},"",2,[],null,"md",[],true,{},"/threads/pages/about",[],"2026-06-21",{"title":6,"description":31},"about","threads/pages/about","用剛剛好的 Tech Stack 開發實用的生活小物 SaaS。",[],"page","Aahi7Oa7mU9Zqu7dVwc1ELfwXrMjl3YRUZ0SmAHZOBY",{"id":50,"title":51,"animated":7,"body":52,"client":34,"cover":66,"css_code":34,"description":56,"extension":35,"html_code":34,"images":67,"is_announcement":7,"is_pinned":37,"is_published":37,"key_points":34,"lang":34,"meta":68,"navigation":37,"order":34,"path":69,"photos":70,"published_at":71,"reading_time":34,"related":34,"role":34,"seo":72,"slug":73,"source_hash":34,"status":34,"stem":74,"summary":75,"tags":76,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":78},"threads/threads/articles/coffee-field.md","咖啡所在",{"type":9,"value":53,"toc":64},[54,57],[15,55,56],{},"Threadspage 試用教學日！",[15,58,59],{},[60,61],"img",{"alt":62,"src":63},"東京晴空塔","/images/gallery/heijitsusanpo.png",{"title":31,"searchDepth":32,"depth":32,"links":65},[],"/images/my space.png",[],{},"/threads/articles/coffee-field",[],"2026-06-13",{"title":51,"description":56},"coffee-field","threads/articles/coffee-field","今天是禮拜六，很幸運沒下雨。⛅︎",[],"article","ksany6QJIRHnrQVp0iJOfruIBR8jdNA46ra4MmIW3Sw",{"id":80,"title":81,"animated":7,"body":82,"client":34,"cover":34,"css_code":34,"description":86,"extension":35,"html_code":34,"images":138,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":139,"navigation":37,"order":34,"path":140,"photos":141,"published_at":142,"reading_time":34,"related":34,"role":34,"seo":143,"slug":144,"source_hash":34,"status":34,"stem":145,"summary":146,"tags":147,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":150},"threads/threads/articles/recap-2025.md","2025 年的碎片",{"type":9,"value":83,"toc":136},[84,87,90,93,96,99,102,105,108,111,114,117,119,122,125,128,130,133],[15,85,86],{},"今年一整年保持著一週健身 3 天，有氧 1 小時的好習慣。規律運動、吃健康的食物真的會感受到原始的快樂！",[15,88,89],{},"腦內啡釋放和身體變得輕盈的感覺真的超好！怪不得大家都說體態是最好的名片，因為運動真的很花時間。🤣",[15,91,92],{},"10 月第一次在國外自駕之旅，去了矽谷找朋友，體驗了美國時間、美國生活。雖然花了很多特休跟錢，但我覺得超值得，因為回憶是會複利的！",[15,94,95],{},"我一直認為時間有美化回憶的能力，時間為苦澀的回憶加上濾鏡，為開心的回憶按下快門。",[15,97,98],{},"我能夠鮮明地感受到 10 年前第一次身在東京的興奮，也確定很久以後，能夠重溫這趟美國之旅的快樂。",[15,100,101],{},"/",[15,103,104],{},"從去年發現 indie hacking 這個領域之後，我嘗試獨立開發一年多了。在今年 8 月發佈了我的第一個產品，一個用 markdown 寫和弦譜的工具《和弦島》。但是太 niche 了，沒什麼人用。",[15,106,107],{},"我沒有能讓產品持續曝光的 distribution channel，只在發佈的那一個禮拜激起一陣漣漪，隔週 GA4 的線圖又恢復平靜了。",[15,109,110],{},"不過在做使用者訪談時，認識了厲害的吉他手（可以 cover Marcin 曲子的等級）也是很棒的收穫！",[15,112,113],{},"獨立開發就和學習任何事情一樣，有前人的經驗可以參考是一回事，事實上總是要自己走過一次、陷進同樣的坑裡才能真的學會一些事情。我想這就是知識和經驗之間的關係吧。",[15,115,116],{},"為了補足開發以外的技能，我攝取了好些英文書：My Indie Book, Snow Leopard, Obviously Awesome, The SaaS Playbook, The Cold Start Problem。之後的產品如果有相關的心得再寫文章分享吧！實作要緊！",[15,118,101],{},[15,120,121],{},"今年也開始跟仰慕很久的吉他老師上課，課堂上經常發現一些平時自己不會注意到的小細節，其實都埋藏著很多學問。六條弦和手臂大小的桶身裡，真的藏著一個宇宙！",[15,123,124],{},"每當這種時候總是能深刻感受到現場教學的價值。雖然現在靠 YouTube 和 AI，沒有什麼東西是不能自學的，但是經驗和「發現自己不知道什麼」的能力，還是需要老師。",[15,126,127],{},"這種時候也會覺得，辛苦上班賺錢終於有意義了，可以付學費學想學的東西。",[15,129,101],{},[15,131,132],{},"2026 年的新年新希望跟往年一樣：希望每年都可以不要許同樣的願望。",[15,134,135],{},"所以就這樣吧～💪🏻",{"title":31,"searchDepth":32,"depth":32,"links":137},[],[],{},"/threads/articles/recap-2025",[],"2025-12-31",{"title":81,"description":86},"recap-2025","threads/articles/recap-2025","時間有美化回憶的能力，時間為苦澀的回憶加上濾鏡，為開心的回憶按下快門。",[148,149],"2025","recap","vbudqgEWAIT97YJTFjWChUtnUCNZvX3MLGK-wzVMf-c",{"id":152,"title":153,"animated":7,"body":154,"client":34,"cover":199,"css_code":34,"description":31,"extension":35,"html_code":34,"images":200,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":201,"navigation":37,"order":34,"path":206,"photos":207,"published_at":208,"reading_time":34,"related":34,"role":34,"seo":209,"slug":210,"source_hash":34,"status":211,"stem":212,"summary":213,"tags":214,"tech_stack":34,"translation_of":34,"type":217,"url":191,"video_url":34,"__hash__":218},"threads/threads/products/reelly.md","Reelly",{"type":9,"value":155,"toc":197},[156,161,164,167,170,173,176,179,182,185,194],[12,157,158],{},[15,159,160],{},"把想吃的店，一秒變成清單是什麼體驗？",[15,162,163],{},"下個月要去東京旅遊，存了一堆抹茶 Reels，卻懶得整理到地圖裡嗎？",[15,165,166],{},"我把這件麻煩事變簡單了！Reelly 能讀懂 IG Reels 的內容，只需要點擊「分享」，剩下的 AI 都會處理👏🏻",[15,168,169],{},"去年我要去東京前，IG 推了一堆抹茶店給我。",[15,171,172],{},"我用截圖存、用書籤存，要出發前打開來 —— 完全找不到當初看到的那間 🫠",[15,174,175],{},"於是我乾脆自己寫了一個工具，它叫做 Reelly。🍜",[15,177,178],{},"在 IG 滑到想去的店，點分享，Reelly 會自動讀懂 Reels 的內容，把店名、地址、推薦品項整理好，存進你的專屬清單。",[15,180,181],{},"下次要找，直接搜尋就好。🔍",[15,183,184],{},"日韓店家也支援，Reelly 是 Web App 不用裝 App，加入主畫面即可像 App 一樣使用。",[15,186,187,188],{},"現在完全免費，有興趣的話來試試 👉🏻 ",[189,190,191],"a",{"href":191,"rel":192},"https://reelly.life",[193],"nofollow",[15,195,196],{},"（下個月要出遊的人，現在開始存剛剛好！🙌🏻）",{"title":31,"searchDepth":32,"depth":32,"links":198},[],"/images/reelly-cover.png",[],{"techStack":202},[203,204,205],"Nuxt","PocketBase","Cloudflare R2","/threads/products/reelly",[],"2025-11-20",{"title":153,"description":31},"reelly","building","threads/products/reelly","🍜 看到好吃的 Reels？分享給我，幫你摘要店家清單🧾",[215,216,203],"SaaS","Food","product","ERUXKcjCaBO7OF0wUJTwlZ-jTfY3OLeHLKwmf7-7KmQ",{"id":220,"title":221,"animated":7,"body":222,"client":34,"cover":548,"css_code":34,"description":549,"extension":35,"html_code":34,"images":550,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":551,"navigation":37,"order":34,"path":553,"photos":554,"published_at":555,"reading_time":34,"related":34,"role":34,"seo":556,"slug":557,"source_hash":34,"status":34,"stem":558,"summary":559,"tags":560,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":563},"threads/threads/articles/effective-engineer-talks-at-google.md","《 The Effective Engineer》作者 Edmond Lau 導讀，增加 impact！！ 矽谷工程師都在做的事。",{"type":9,"value":223,"toc":538},[224,232,235,244,253,262,265,278,281,288,291,307,312,315,326,335,338,344,347,352,359,364,371,374,377,380,383,389,396,400,406,409,412,415,422,426,429,432,443,450,454,461,464,471,474,479,482,485,492,496,503,506,510,517,520,524,527,534],[15,225,226,227,231],{},"在傍晚吃飯時間，看著 VSCode 上抽象再抽象的程式碼、Terminal 上惱人的錯誤訊息，這時 Slack 又跳出通知，有緊急的 Bug 票需要解決。螢幕右上角的時鐘，不知道什麼時候已經又過了一小時。明明下班時間都已經到了，今天的進度卻才剛開始沒多久。這時候你不禁感嘆，",[228,229,230],"strong",{},"上班就和爬山一樣，下班路比上班難","。",[15,233,234],{},"你是否有過這樣的時期，上班的時候事情永遠做不完，今天的進度一直往後堆積，每到禮拜五總是加班到接近12點。內心開始自我懷疑，是不是技術能力不足、效率太差，還是工作真的太多了。",[15,236,237,238,243],{},"最近發現幾個技術部落格都推薦了",[189,239,242],{"href":240,"rel":241},"https://www.effectiveengineer.com/book",[193],"《 The Effective Engineer》","這本書，說非常受用，於是我決心來好好研讀一番，期許未來自己也能夠成為一位 effective engineer。",[15,245,246,247,252],{},"我先看了作者在 ",[189,248,251],{"href":249,"rel":250},"https://www.youtube.com/watch?v=BnIz7H5ruy0",[193],"Talks at Google 的演講","，這場演講涵蓋了《 The Effective Engineer》的主要內容。本篇文章會重點摘要演講的內容，書的內容等我看完之後再另外寫文章發表。",[15,254,255,256,261],{},"作者 ",[189,257,260],{"href":258,"rel":259},"http://www.effectiveengineer.com/about",[193],"Edmond Lau"," 在許多知名的矽谷大公司（e.g. Google）和新創公司（e.g. Quora）工作過。他曾經連續 2 年每週工作 80 小時以上，並且又花了 2 年，全職研究如合成為一個 effective engineer。",[15,263,264],{},"藉由訪問 20 幾家矽谷科技巨頭以及新創公司（e.g. Facebook, Instagram, Dropbox, Etsy 等等）的 CTO 和技術大神，問他們以下 3 個問題：",[266,267,268,272,275],"ul",{},[269,270,271],"li",{},"What separates the most effective engineers you have worked with from everyone else?（什麼事情造就了有效率的工程師，使他們有別於普通的工程師？）",[269,273,274],{},"What is the most valuable lesson you have learned in the past year?（你過去一年之中，學到最寶貴的教訓是什麼？）",[269,276,277],{},"What investment you have made for your team has paid off the highest returns?（什麼投資給你的團隊帶來了最高的回報？）",[15,279,280],{},"總結出每個軟體工程師都可以學習的效率工作法。作者稱之為 leverage framework。",[15,282,283,284,287],{},"這本書裡不會有任何一行 code，書中所闡述的，是作為一名軟體工程師，如何藉由",[228,285,286],{},"執行 high-leverage activities 來最大化自己的 impact","，槓桿出自己的價值與影響力。",[15,289,290],{},"作者要我們了解一個殘酷的事實：",[292,293,297],"pre",{"className":294,"code":295,"language":296,"meta":31,"style":31},"language-javascript shiki shiki-themes github-dark","effort === impact // False\n","javascript",[298,299,300],"code",{"__ignoreMap":31},[301,302,305],"span",{"class":303,"line":304},"line",1,[301,306,295],{},[12,308,309],{},[15,310,311],{},"努力不等於影響力與貢獻",[15,313,314],{},"一位 staff engineer 的產出貢獻，可能是一位 junior engineer 的 10 倍，但是前者的工時，不可能也是 10 倍。",[15,316,317,318,321,322,325],{},"作者在此給出了本書的核心概念「",[228,319,320],{},"leverage","」，它是一個放大器，可以將你的努力轉換成巨大的產值和影響力，同時也是",[228,323,324],{},"突破日常開發瑣事的施力點","。以下是 leverage 的計算公式：",[292,327,329],{"className":294,"code":328,"language":296,"meta":31,"style":31},"leverage = impactProduced / timeInvested\n",[298,330,331],{"__ignoreMap":31},[301,332,333],{"class":303,"line":304},[301,334,328],{},[15,336,337],{},"工程師的開發日常，也符合 80 / 20 法則。20% 的任務創造了 80% 的價值和影響，而 80% 的任務，只帶來了 20% 的成效。",[15,339,340,341,231],{},"作者要我們辨識那些花最少時間，卻能創造最大價值和影響力的事情，並且優先去執行它，這些影響至關重大的事情叫做 ",[228,342,343],{},"high-leverage activities",[15,345,346],{},"在演講中，作者提及了以下 5 種 high-leverage activity ，就讓我們一一來了解吧！",[348,349,351],"h3",{"id":350},"optimize-for-learning","Optimize for learning",[15,353,354,355,358],{},"第一個 high-leverage activity 是最大化自己學習能力。因為，",[228,356,357],{},"學習是有複利效果的","！所以越早開始進步的幅度越大，學習能力越好，進步得越快。",[12,360,361],{},[15,362,363],{},"Learning compounds!",[15,365,366,367,370],{},"因為學習具有複利效果，所以能力的成長曲線呈",[228,368,369],{},"指數增長","，一開始緩緩上升，幾乎是平的，但過了某一個臨界點之後，會近乎垂直地向上攀升。",[15,372,373],{},"這也滿符合事實，當要攻克一個難題時，需要累積不同面向的知識，當知識點連成線之後，就能夠兜出解法解決問題了。",[15,375,376],{},"作者舉了一個老生常談的例子，每天進步 1%，一年後，會進步 37 倍！",[15,378,379],{},"要努力學習這個大家都知道，但困難的地方是，我們常常被淹沒在日常的開發瑣事、隕石一般的 bug 轟炸之中。每天要做的事情都做不完了，要怎麼騰出時間來學習呢？",[15,381,382],{},"在書中，作者舉了一個 Google 的例子，為了提升員工的生產力與創造力，Google 實行了 20% Time，每週空出一天做自己本職工作以外的事情，研究新的技術、做自己有興趣的專案等等。例如 Gmail 就是從 20% Time 中誕生的。",[15,384,385,386,231],{},"但是身為一般公司的員工，不可能每個禮拜空出一天。於是作者建議，我們可以",[228,387,388],{},"每天預留 1 小時的工時，來實行自己的 20% Time",[15,390,391,392,395],{},"關於學習的最後一點，作者建議我們可以從自己感興趣，或是工作上面臨的問題著手研究，因為",[228,393,394],{},"動機","永遠是持續一項行動最重要的元素。",[348,397,399],{"id":398},"invest-in-iteration-speed","Invest in iteration speed",[15,401,402,403,231],{},"第二個 high-leverage activity 是加速處理重複事務的速度。這和決定是否要將一段 code 寫成一個 function 的判斷方式一樣，當一件事情重複做第二次的時候，你就應該想辦法",[228,404,405],{},"讓第三次作業能夠自動化地進行",[15,407,408],{},"在作者問了每個 CTO，什麼事情造就了有效率的工程師，使他們有別於普通的工程師的時候，他們回答：「會投資時間自己寫一些自動化小工具的工程師，往往效率都是最高的。」",[15,410,411],{},"這裡說的小工具，小到 shell script，大到整個 CI/CD 的自動化基礎建設，都包含在內。",[15,413,414],{},"作者舉例，之前他在 Quora 工作時，每天平均會部署 40～50 次，可以想見如果沒有 CI/CD 的自動化流程，會花費多麼龐大的時間。",[15,416,417,418,421],{},"許多矽谷的大公司都有專門的 team 在打造內部開發工具，像是 facebook 開發了 React.js。作者說：「",[228,419,420],{},"我們都很想成為某個新潮 framework 的作者，但其實，從每天的開發日常，就可以開始了","！」",[348,423,425],{"id":424},"validate-your-ideas-aggressively-and-iteratively","Validate your ideas aggressively and iteratively",[15,427,428],{},"第三個 high-leverage activity 是盡量在進到實作的階段之前，就先驗證 feature 的可行性，避免浪費不必要的時間以及人力。",[15,430,431],{},"舉例來說，Etsy 把產品搜尋結果頁面改成可以無限捲動。在上線之前，他們做了 A/B test，發現點擊率和轉換率各自下跌了 10% 和 25%。因此，這個功能最後根本無法上線，白白浪費了幾個月的時間和人力。",[15,433,434,435,438,439,442],{},"有了這次的經驗，Esty 在修改產品內容頁面的時候，採取",[228,436,437],{},"漸進式","的做法，先將想做的 feature 拆解成幾個",[228,440,441],{},"可以驗證的前提假設","，確認對產品有幫助之後，才真的開始開發。",[15,444,445,446,449],{},"作者說，在一個專案裡，",[228,447,448],{},"越是不確定、有風險的事情，越要在第一時間執行","，避免後續做白工。",[348,451,453],{"id":452},"minimize-operational-burden","Minimize operational burden",[15,455,456,457,460],{},"第四個 high-leverage activity 是要盡量降低日常維護的成本，作者在演講中著重在",[228,458,459],{},"複雜度 complexity"," 的討論上。",[15,462,463],{},"當 Instagram 被 facebook 收購的時候，服務著 4000 萬的使用者，員工卻只有 13 人，其中只有 5 位是工程師。無論從什麼角度來看，他們絕對是一個超級有效率的團隊。",[15,465,466,467,470],{},"作者訪問他們的 CTO，是什麼造就了這一切？CTO 的回答是：「我們",[228,468,469],{},"只採取最簡單的做法來解決問題","。工程師們互相詰問，確認不會增加後續維護的成本之後，才會進行開發。」",[15,472,473],{},"作者說複雜度的影響，從小至大都可能存在。",[12,475,476],{},[15,477,478],{},"code complexity -> system complexity -> product complexity -> organization complexity。",[15,480,481],{},"複雜的 code 會增加工程師的理解和互相溝通的成本、系統的複雜度會增加維護的成本、產品功能的複雜度越高，會讓未來開發的功能的難度增加、甚至是組織上的複雜度，都會影響到開發團隊的效率。",[15,483,484],{},"作者有一次在夏威夷休假，但是剛好有一個只有他懂的系統出問題，而火山上面沒有網路可以處理 bug，於是他就直接變成 single point of failure 了⋯⋯",[15,486,487,488,491],{},"於是作者開始重視 ",[228,489,490],{},"mentorship","，製作詳盡的 on boarding 文件和流程。原本入職三個月的工程師還在理解 code base，現在剛入職的工程師，在第一個禮拜就可以開始貢獻 production。這真的是非常巨大的效率改善！",[348,493,495],{"id":494},"building-a-great-engineering-culture","Building a great engineering culture",[15,497,498,499,502],{},"第五個 high-leverage activity 是建立良好的開發團隊文化。工程師們都想在聊好的環境中工作，",[228,500,501],{},"專注於 leverage activities，會成為一個正向循環","，讓效率推進越來越順手。",[15,504,505],{},"最後是一些 Q&A：",[348,507,509],{"id":508},"q-寫測試雖然必要但是很花時間有沒有更有效率的寫測試方法","Q: 寫測試雖然必要，但是很花時間，有沒有更有效率的寫測試方法？",[15,511,512,513,516],{},"A: 可以",[228,514,515],{},"先確保重要的環節都有測試覆蓋","，在頻繁的改動下不會出錯為目標。",[15,518,519],{},"整個系統不一定要有 100% 的 test coverage，在很少用到的地方寫測試，有時候可能是一種浪費。",[348,521,523],{"id":522},"q-你提到的例子都是新創公司或規模不大的公司關於減低複雜度有沒有在大公司也適用的方法呢","Q: 你提到的例子都是新創公司或規模不大的公司，關於減低複雜度，有沒有在大公司也適用的方法呢？",[15,525,526],{},"A: 新創公司的好處是大家容易直接溝通，但大公司也有它的優點，例如容易取得歷史數據。",[15,528,529,530,533],{},"以 Google 來說，它是一間非常 Data-driven 的公司，所以可以",[228,531,532],{},"讓數據說話，影響決策者","做出 leverage activities。",[535,536,537],"style",{},"html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}",{"title":31,"searchDepth":32,"depth":32,"links":539},[540,542,543,544,545,546,547],{"id":350,"depth":541,"text":351},3,{"id":398,"depth":541,"text":399},{"id":424,"depth":541,"text":425},{"id":452,"depth":541,"text":453},{"id":494,"depth":541,"text":495},{"id":508,"depth":541,"text":509},{"id":522,"depth":541,"text":523},"/images/effective-engineer.jpg","在傍晚吃飯時間，看著 VSCode 上抽象再抽象的程式碼、Terminal 上惱人的錯誤訊息，這時 Slack 又跳出通知，有緊急的 Bug 票需要解決。螢幕右上角的時鐘，不知道什麼時候已經又過了一小時。明明下班時間都已經到了，今天的進度卻才剛開始沒多久。這時候你不禁感嘆，上班就和爬山一樣，下班路比上班難。",[],{"readingTime":552},8,"/threads/articles/effective-engineer-talks-at-google",[],"2023-05-11",{"title":221,"description":549},"effective-engineer-talks-at-google","threads/articles/effective-engineer-talks-at-google","每天預留 1 小時的工時，來實行自己的 20% Time。",[561,562],"effective engineer","high leverage","ns_O1uYxzH24KU29S8VH6qdBCwQTjy11MmCTogKBlwo",{"id":565,"title":566,"animated":7,"body":567,"client":34,"cover":577,"css_code":34,"description":571,"extension":35,"html_code":34,"images":578,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":579,"navigation":37,"order":34,"path":580,"photos":581,"published_at":583,"reading_time":34,"related":34,"role":34,"seo":584,"slug":585,"source_hash":34,"status":34,"stem":586,"summary":587,"tags":588,"tech_stack":34,"translation_of":34,"type":592,"url":34,"video_url":34,"__hash__":593},"threads/threads/gallery/tokyo-wide-sanpo.md","東京廣域散步",{"type":9,"value":568,"toc":575},[569,572],[15,570,571],{},"四月的東京，上野公園的染井吉野正盛開。",[15,573,574],{},"人群與花瓣一起在風中飄散，每年此刻，這座城市都暫時把它的效率感放下。",{"title":31,"searchDepth":32,"depth":32,"links":576},[],"/images/gallery/uzawaechigo.jpeg",[],{},"/threads/gallery/tokyo-wide-sanpo",[577,582],"/images/gallery/urikamome.jpg","2023-04-21",{"title":566,"description":571},"tokyo-wide-sanpo","threads/gallery/tokyo-wide-sanpo","2023 年春季剪影",[589,590,591],"旅遊","東京","春天","gallery","Dvppaz0RPv2sCHIbs0tz3Leyp8_nylkgiC_g4drF7hk",{"id":595,"title":596,"animated":7,"body":597,"client":34,"cover":630,"css_code":34,"description":601,"extension":35,"html_code":34,"images":631,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":632,"navigation":37,"order":34,"path":633,"photos":634,"published_at":635,"reading_time":34,"related":34,"role":34,"seo":636,"slug":637,"source_hash":34,"status":34,"stem":638,"summary":639,"tags":640,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":643},"threads/threads/articles/sankahakuu.md","東京散步 ｜ 両国篇",{"type":9,"value":598,"toc":628},[599,602,605,608,614,617,620,623],[15,600,601],{},"一直以來最喜歡的北齋浮世繪作品都是《神奈川沖浪裏》",[15,603,604],{},"因為那開出萬千白花的浪尖，生動得彷彿是許多小手想將單薄的小船攫走。",[15,606,607],{},"這彷彿讓我看見，北齋畫了一輩子，終於在年老時遇見了普魯士藍，得以在畫布上自由揮灑江戶的海與天空的狂喜。",[15,609,610,611,231],{},"但今天在北齋美術館，看到了《山下白雨》這幅作品。一下子也躍升為我",[228,612,613],{},"最喜歡的北齋作品",[15,615,616],{},"在《山下白雨》中，山腳下烏雲密佈、雷電交加，而富士山山頂卻穿越雲雨，聳立在晴朗的天空中。",[15,618,619],{},"在有限的畫布上，北齋為了表現出富士山的雄偉，用了天氣作為對比，襯托出立體的高度。",[15,621,622],{},"在好的作品中，這種巧思好像無處不在。文學、攝影、繪畫、音樂，都有各自的方式。",[12,624,625],{},[15,626,627],{},"我想，能將心中的想像，用手邊的工具實現的人。放在什麼時代，都是最厲害的吧！",{"title":31,"searchDepth":32,"depth":32,"links":629},[],"/images/sankahakuu.png",[],{"readingTime":552},"/threads/articles/sankahakuu",[],"2023-03-17",{"title":596,"description":601},"sankahakuu","threads/articles/sankahakuu","我彷彿看見，北齋畫了一輩子，終於在年老時遇見了普魯士藍，得以在畫布上自由揮灑江戶的海與天空的狂喜。",[641,642],"葛飾北齋","富嶽三十六景","QDTUujuO4YttNiwcqEQuzgLHg5sk0HMrdKWTh4-Z7m8",{"id":645,"title":646,"animated":7,"body":647,"client":34,"cover":736,"css_code":34,"description":31,"extension":35,"html_code":34,"images":737,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":738,"navigation":37,"order":34,"path":739,"photos":740,"published_at":741,"reading_time":34,"related":34,"role":34,"seo":742,"slug":743,"source_hash":34,"status":34,"stem":744,"summary":745,"tags":746,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":747},"threads/threads/articles/liuyi-english-school.md","孩子們的南陽街與大人們的補習班",{"type":9,"value":648,"toc":734},[649,654,657,660,663,666,669,676,679,682,685,688,691,694,699,714,721],[12,650,651],{},[15,652,653],{},"「接下來的大學四年，將會是你們人生中過最爽的日子。」",[15,655,656],{},"Wayne 老師堅定的語氣，與其說是在向我們預告，更像是在回憶。「你們會發現，高中時期曾經覺得很厲害的大型成發、深刻的戀愛，原來是那麼地小兒科。在大學裡，永遠有更令你興奮的事情可以去做。你們要非常珍惜這段時光。因為，人生最爽、最無憂無慮的時候，可能真的就是大學這四年了。」",[15,658,659],{},"這是我高三的這一年中，在劉毅英文記憶最深刻的一句話。大我們 10 歲的 Wayne 老師，對高中生來說，不是一個長輩，而是同儕般的存在。他在課堂間偶爾閒談起的回憶，是我們在書堆中仰望的未來。升上大學以後，就是個大人了。自由彷彿唾手可得，那會是什麼樣的感覺呢?",[15,661,662],{},"《孩子們的南陽街與大人們的補習班》是一本記錄高中生們的青春歲月、也報導大人們的補習班事業的回憶錄。最初，我是在台下聽講的學生。本書出版後，我是該開始 ( 但拖延 ) 思考未來的大三生。再次閱讀，我已工作兩年並且轉職到理想跑到的上班族。每次閱讀本書都有不同的體驗，有種少年聽雨的感覺。",[15,664,665],{},"最大的不同，是初次閱讀時，我完全把焦點放在學生的部分，覺得這個學生好奇特、這個學生的煩惱我也有等等。而再次閱讀時，我則不由自主地關注 Wayne 老師在補習班的經歷，周旋於管理階層之間的為難。",[15,667,668],{},"同時也意識到了，當年滿心期待的每週三晚上，讓我感到能夠窺見大人自由世界的模考班解題時間，其實是扎扎實實地，經歷了許多苦練、苦澀，甚至是自我懷疑，才得以展現在我們面前。出社會工作了以後，才注意到光鮮亮麗背後的辛苦付出。",[15,670,671,672,675],{},"本書的作者 蔡世偉 ",[298,673,674],{},"@waynetsai1984"," 為補習班老師、 知名英文譯者。曾經翻譯過的書籍有：《原子習慣》、《我是GaryVee》、《麥可喬丹傳》、《曼巴精神》、《每一天的覺醒》等等。",[15,677,678],{},"本書一共分為三個部分，分別是「那些學生教我的事」、「補習班的那些事」以及隱藏版內容「課間閒談」。",[15,680,681],{},"「那些學生教我的事」是 Wayne 老師在補習班中所教到的奇葩學生，有母管嚴的森哥、熱愛山本五十六的軍事迷、考試與烘焙都臻至頂尖的北一女甜點師。每一位被提及的高中生，在努力符合學測、指考這個品管標準的，高中教育標準化製造流程下，都顯得特別的突出。突出的原因可能是有特別熱愛的興趣、特別擅長的技能，甚至是特別地聽話、不反抗。看完這部分後，不禁想到 Pink Floyd 樂團的 Another Brick In The Wall。教育究竟是讓我們變得更好，還是一種篩選機制呢?",[15,683,684],{},"「補習班的那些事」紀錄了 Wayne 老師在劉毅英文中的經歷與遭遇。從入行到成為補習班王牌老師。從光鮮亮麗的講台到下課的備課時間、再到與補習班管理層間的周旋等等。其中讓我印象最深刻的是補習班老闆劉毅曾經對 Wayne 老師說：「我討厭你！」。即便如此，Wayne 老師還是在書中表示他自己非常尊敬劉毅老師。其中最大的原因是，他被劉毅教英文的熱情所感動。劉毅曾經在講台上說過：「萬一我突然死掉了也沒有關係，我已經把講義都編好了，會有老師代替我上下去。」",[15,686,687],{},"我自己在高中補習的時候，每學期都會拿到劉毅出版社新編的單字書、文法書、句型書。雖然實際上沒有多少人看，但這種對於自己在乎的事情，展現捨我其誰的態度去做的精神，也深刻地感動到了我。",[15,689,690],{},"「課間閒談」節錄了十幾句 Wayne 老師在閱讀中深獲啟發的文字，並且加上他的人生經驗作為印證，是本書中我最喜歡的部分。日本出版社幻冬社的老闆見城徹曾經說過「重要的不是書中寫了什麼，而是自己如何感受。」在讀課間閒談時，我的腦中突然浮現了這句話。",[15,692,693],{},"Wayne 老師熱愛閱讀，並且藉由自己的人生經驗和作者們對話。閱讀《孩子們的南陽街與大人們的補習班》可以看見那些走在我們人生前面的人，反覆思索的問題與回答。同時也能知道，不是只有我一個人有這些煩惱。雖然我們必須靠自己過好自己的人生，但是我們並不孤獨。😉",[12,695,696],{},[15,697,698],{},"The reading of all good books is like conversation with the finest men of past centuries. - René Descartes\n閱讀好書，如同與過往世代的人傑們對話。 - 勒內·笛卡兒",[15,700,701,702,705,706,709,710,713],{},"電子化的浪潮席捲而來，每個人都無法置身事外。選擇讀墨帶你在文字之海中乘風破浪吧！點擊以下連結",[228,703,704],{},"註冊讀墨會員","，30 天內首購享 ",[228,707,708],{},"79 折","，60 天內單筆訂單滿額再送 ",[228,711,712],{},"$100 購書金","！",[15,715,716,717],{},"立即註冊 👉 ",[189,718,719],{"href":719,"rel":720},"http://moo.im/i/DbsBO",[193],[15,722,723,724,729,730],{},"立即購買",[189,725,728],{"href":726,"rel":727},"https://readmoo.com/book/210208251000101",[193],"《孩子們的南陽街與大人們的補習班》","喚起那些憧憬大人世界的夏日回憶 👉 ",[189,731,732],{"href":732,"rel":733},"https://moo.im/a/3fglvC",[193],{"title":31,"searchDepth":32,"depth":32,"links":735},[],"/images/wayne-english-teacher.png",[],{"readingTime":552},"/threads/articles/liuyi-english-school",[],"2021-09-05",{"title":646,"description":31},"liuyi-english-school","threads/articles/liuyi-english-school","升上大學以後，就是個大人了。自由彷彿唾手可得，那會是什麼樣的感覺呢?",[],"rwoj49CgDpCIsnbiHFEFqoqHyyfC0NLvJI4uKfXdTxU",{"id":749,"title":750,"animated":37,"body":751,"client":34,"cover":34,"css_code":755,"description":31,"extension":35,"html_code":756,"images":757,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":758,"navigation":37,"order":34,"path":759,"photos":760,"published_at":761,"reading_time":34,"related":34,"role":34,"seo":762,"slug":763,"source_hash":34,"status":34,"stem":764,"summary":765,"tags":766,"tech_stack":34,"translation_of":34,"type":770,"url":34,"video_url":34,"__hash__":771},"threads/threads/cssart/face-mask.md","口罩圖鑑",{"type":9,"value":752,"toc":753},[],{"title":31,"searchDepth":32,"depth":32,"links":754},[],".mask-art * {\n  box-sizing: border-box;\n  margin: 0;\n  padding: 0;\n  text-decoration: none;\n  list-style-type: none;\n  letter-spacing: 4px;\n  font-size: 20px;\n}\n\n.mask-art {\n  background-color: #a98e7c;\n  color: #ddd;\n  padding: 20px 0;\n}\n\n.mask-art .container {\n  margin: 0 auto;\n  width: 700px;\n  max-width: 100%;\n}\n\n.mask-art .prod-wrapper {\n  width: 100%;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n\n.mask-art .prod-name {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  text-align: center;\n  padding: 30px 0;\n  margin: 20px 30px;\n  width: 30%;\n}\n\n.mask-art .mask-wrapper {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  text-align: center;\n  padding: 30px 0;\n  margin: 20px 0;\n  width: 40%;\n}\n\n.mask-art .desc {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  text-align: left;\n  margin: 20px 0 20px 70px;\n  width: 30%;\n  font-size: 16px;\n}\n\n/* 醫療口罩 */\n.mask-art .mask {\n  position: relative;\n  width: 200px;\n  height: 90px;\n  background-color: #87f0df;\n  border: 3px dotted #eee;\n  border-top: 4px solid #eee;\n  border-radius: 2px;\n  transition: all 0.7s;\n}\n\n.mask-art .mask:hover {\n  transform: translate(0, -5px);\n  box-shadow: 0px 20px 10px rgba(0, 0, 0, 0.4);\n}\n\n.mask-art .mask .iron-line {\n  margin: 6px auto;\n  width: 190px;\n  border: 2px solid #eee;\n}\n\n.mask-art .mask .line {\n  margin: 20px auto;\n  width: 190px;\n  border: 1px solid #eee;\n}\n\n.mask-art .mask::before {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 2px solid #eee;\n  border-right: 2px dotted #eee;\n  left: -50px;\n  border-radius: 40px 0px 0px 40px;\n}\n\n.mask-art .mask::after {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 2px solid #eee;\n  border-left: 2px dotted #eee;\n  top: 0;\n  right: -50px;\n  border-radius: 0px 40px 40px 0px;\n}\n\n/* 活性碳口罩 */\n.mask-art .carbon-mask {\n  position: relative;\n  width: 200px;\n  height: 90px;\n  background-image: radial-gradient(#778683 70%, #aab3b2 30%);\n  background-size: 2px 2px;\n  border: 3px dotted #ddd;\n  border-top: 4px solid #ddd;\n  border-radius: 2px;\n  transition: all 0.7s;\n}\n\n.mask-art .carbon-mask:hover {\n  transform: translate(0, -5px);\n  box-shadow: 0px 20px 10px rgba(0, 0, 0, 0.4);\n}\n\n.mask-art .carbon-mask .iron-line {\n  margin: 6px auto;\n  width: 190px;\n  border: 2px solid #ddd;\n}\n\n.mask-art .carbon-mask .line {\n  margin: 20px auto;\n  width: 190px;\n  border: 1px solid #aab3b2;\n}\n\n.mask-art .carbon-mask::before {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 2px solid #eee;\n  border-right: 2px dotted #eee;\n  left: -50px;\n  border-radius: 40px 0px 0px 40px;\n}\n\n.mask-art .carbon-mask::after {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 2px solid #eee;\n  border-left: 2px dotted #eee;\n  top: 0;\n  right: -50px;\n  border-radius: 0px 40px 40px 0px;\n}\n\n/* N95 口罩 */\n.mask-art .n95-mask {\n  position: relative;\n  width: 150px;\n  height: 150px;\n  background-image: radial-gradient(#eee, rgb(177, 177, 177));\n  background-size: cover;\n  border: 3px solid #ccc;\n  border-radius: 75px 40px 75px 75px;\n  transform: rotate(-45deg);\n  transition: 0.7s;\n}\n\n.mask-art .n95-mask:hover {\n  transform: translate(0, -10px) rotate(-45deg);\n  box-shadow: 0px 20px 10px rgba(0, 0, 0, 0.4);\n}\n\n.mask-art .n95-mask .iron-line-left {\n  position: absolute;\n  top: 8%;\n  left: 22%;\n  margin: 6px auto;\n  width: 90px;\n  border: 2px solid #ddd;\n  transform: rotate(5deg);\n}\n\n.mask-art .n95-mask .iron-line-right {\n  position: absolute;\n  top: 42%;\n  left: 54%;\n  margin: 6px auto;\n  width: 90px;\n  border: 2px solid #ddd;\n  transform: rotate(85deg);\n}\n\n.mask-art .n95-mask .filter {\n  position: absolute;\n  top: 6px;\n  left: 16px;\n  margin: 20px auto;\n  width: 30px;\n  height: 30px;\n  background-image: radial-gradient(#ddd 60%, rgb(177, 177, 177) 40%);\n  background-size: contain;\n  border: 2px dotted #ddd;\n  border-radius: 50%;\n}\n\n.mask-art .n95-mask .mark {\n  position: absolute;\n  top: 88px;\n  left: 2%;\n  width: 90px;\n  height: 20px;\n  background-color: #ddd;\n  border: 1px dotted #aab3b2;\n  transform: rotate(45deg);\n  font-size: 10px;\n  color: #666;\n  letter-spacing: 0;\n  font-weight: 600;\n}\n\n.mask-art .n95-mask::before {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 2px solid #eee;\n  border-right: 2px dotted #eee;\n  top: -32px;\n  left: -16px;\n  border-radius: 40px 0px 0px 40px;\n  transform: rotate(45deg);\n}\n\n.mask-art .n95-mask::after {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 2px solid #eee;\n  border-left: 2px dotted #eee;\n  top: 87px;\n  right: -17px;\n  border-radius: 0px 40px 40px 0px;\n  transform: rotate(45deg);\n}\n\n/* 國王的口罩（買不到） */\n.mask-art .no-mask {\n  position: relative;\n  width: 200px;\n  height: 90px;\n  background-color: transparent;\n  border: 1px dotted #eee;\n  border-radius: 2px;\n  transition: all 0.7s;\n}\n\n.mask-art .no-mask:hover {\n  transform: translate(0, -5px);\n}\n\n.mask-art .no-mask .line {\n  margin: 30px auto;\n  width: 190px;\n  color: #444;\n  text-decoration: line-through;\n}\n\n.mask-art .no-mask::before {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 1px dotted #eee;\n  top: 2px;\n  left: -50px;\n  border-radius: 40px 0px 0px 40px;\n}\n\n.mask-art .no-mask::after {\n  content: \"\";\n  display: block;\n  width: 50px;\n  height: 80px;\n  position: absolute;\n  border: 1px dotted #eee;\n  top: 2px;\n  right: -50px;\n  border-radius: 0px 40px 40px 0px;\n}\n\n@media (max-width: 768px) {\n  .mask-art .container {\n    width: 90%;\n  }\n\n  .mask-art .prod-wrapper {\n    flex-direction: column;\n    margin: 0 auto;\n  }\n\n  .mask-art .prod-name {\n    width: 100%;\n    margin: 20px auto 0;\n    padding: 0;\n  }\n\n  .mask-art .mask-wrapper {\n    width: 100%;\n    margin-bottom: 30px;\n    padding: 0;\n  }\n\n  .mask-art .desc {\n    width: 60%;\n    margin: 0 auto 30px;\n  }\n}\n","\u003Cdiv class=\"mask-art\">\n  \u003Cdiv class=\"container\">\n    \u003Cdiv class=\"prod-wrapper\">\n      \u003Cdiv class=\"prod-name\">醫療口罩\u003C/div>\n      \u003Cdiv class=\"mask-wrapper\">\n        \u003Cdiv class=\"mask\">\n          \u003Cdiv class=\"iron-line\">\u003C/div>\n          \u003Cdiv class=\"line\">\u003C/div>\n          \u003Cdiv class=\"line\">\u003C/div>\n          \u003Cdiv class=\"line\">\u003C/div>\n        \u003C/div>\n      \u003C/div>\n      \u003Cdiv class=\"desc\">可有效阻擋大部分飛沫，適合一般民眾配戴。\u003C/div>\n    \u003C/div>\n    \u003Cdiv class=\"prod-wrapper\">\n      \u003Cdiv class=\"prod-name\">活性碳口罩\u003C/div>\n      \u003Cdiv class=\"mask-wrapper\">\n        \u003Cdiv class=\"carbon-mask\">\n          \u003Cdiv class=\"iron-line\">\u003C/div>\n          \u003Cdiv class=\"line\">\u003C/div>\n          \u003Cdiv class=\"line\">\u003C/div>\n          \u003Cdiv class=\"line\">\u003C/div>\n        \u003C/div>\n      \u003C/div>\n      \u003Cdiv class=\"desc\">可吸附異味，大多數無法隔絕飛沫，沒有防疫效果。\u003C/div>\n    \u003C/div>\n    \u003Cdiv class=\"prod-wrapper\">\n      \u003Cdiv class=\"prod-name\">N95 口罩\u003C/div>\n      \u003Cdiv class=\"mask-wrapper\">\n        \u003Cdiv class=\"n95-mask\">\n          \u003Cdiv class=\"iron-line-left\">\u003C/div>\n          \u003Cdiv class=\"iron-line-right\">\u003C/div>\n          \u003Cdiv class=\"filter\">\u003C/div>\n          \u003Ci class=\"mark\"> Warning 3M\u003C/i>\n        \u003C/div>\n      \u003C/div>\n      \u003Cdiv class=\"desc\">可有效阻絕 95％ 以上的病毒，適合長時間接觸患者的第一線醫療人員配戴。\u003C/div>\n    \u003C/div>\n    \u003Cdiv class=\"prod-wrapper\">\n      \u003Cdiv class=\"prod-name\">國王的口罩\u003C/div>\n      \u003Cdiv class=\"mask-wrapper\">\n        \u003Cdiv class=\"no-mask\">\n          \u003Cdiv class=\"iron-line\">\u003C/div>\n          \u003Cdiv class=\"line\">買不到\u003C/div>\n        \u003C/div>\n      \u003C/div>\n      \u003Cdiv class=\"desc\">身體健康、從事戶外運動，現階段可以不用戴口罩。\u003C/div>\n    \u003C/div>\n  \u003C/div>\n\u003C/div>\n",[],{},"/threads/cssart/face-mask",[],"2020-02-06",{"title":750,"description":31},"face-mask","threads/cssart/face-mask","2020 年口罩實名制上路，用純 CSS 畫下那個全民搶口罩的年代：醫療口罩、活性碳口罩、N95、還有「買不到」的國王口罩。",[767,768,769],"CSS Art","Pure CSS","2020","cssart","ExrxwA1mT318QSStUg-lJCJm6bvqoqtkMmq2lh48txA",{"id":773,"title":774,"animated":37,"body":775,"client":34,"cover":34,"css_code":807,"description":779,"extension":35,"html_code":808,"images":809,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":810,"navigation":37,"order":34,"path":811,"photos":812,"published_at":813,"reading_time":34,"related":34,"role":34,"seo":814,"slug":815,"source_hash":34,"status":34,"stem":816,"summary":817,"tags":818,"tech_stack":34,"translation_of":34,"type":770,"url":34,"video_url":34,"__hash__":821},"threads/threads/cssart/bubble-tea.md","珍珠奶茶手搖杯",{"type":9,"value":776,"toc":805},[777,780,783,794,797,800],[15,778,779],{},"Vue.js 櫻花珍珠手搖杯，現在就來為自己調一杯珍奶吧！",[15,781,782],{},"你可以：",[266,784,785,788,791],{},[269,786,787],{},"選擇杯型（保溫杯、手搖杯、咖啡杯、馬克杯）",[269,789,790],{},"調整各種成分的比例（奶蓋、牛奶、綠茶、紅茶）",[269,792,793],{},"增減珍珠數量",[15,795,796],{},"本點餐系統提供 4 種飲品、4 款杯子，供顧客自由搭配選用。",[15,798,799],{},"建議選用環保杯，因為",[12,801,802],{},[15,803,804],{},"地球已經太擁擠了，再也容不下一點塑膠！",{"title":31,"searchDepth":32,"depth":32,"links":806},[],".bubble-tea-container {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  min-height: 200px;\n  background-color: #698474;\n  padding: 24px;\n}\n.label { color: #e5e4cc; margin-top: 12px; font-size: 14px; }\n.beverage { position: relative; margin-top: 30px; }\n.cup {\n  width: 60px; height: 100px; margin: 0 auto;\n  border: 4px solid #fff; border-top: none;\n  padding-top: 5px; position: relative;\n}\n.ingradients {\n  width: 100%; position: absolute; bottom: 0;\n  background-color: #9dab86; overflow: hidden; font-size: 0;\n}\n.thermos-height { max-height: 80px; }\n.bubbles {\n  width: 10px; height: 10px; background-color: #fbc1bc;\n  border-radius: 5px; display: inline-block;\n}\n.green-tea { width: 100%; height: 25px; background-color: #9dab86; }\n.milk { width: 100%; height: 25px; background-color: #f7d8bb; }\n.foam { width: 100%; height: 10px; background-color: #eee; }\n.black-tea { width: 100%; height: 0; background-color: #801a08; }\n.box { width: 100%; height: 10px; position: absolute; top: 0; overflow: hidden; z-index: 1; }\n.wave {\n  position: absolute; bottom: 47%; left: -147%;\n  background: #698474; width: 222px; height: 222px;\n  transform-origin: 50% 48%; border-radius: 43%;\n  animation: drift 5000ms infinite linear;\n}\n.wave.-three { animation: drift 7000ms infinite linear; }\n.wave.-two { animation: drift 9000ms infinite linear; opacity: .1; background: #f8b195; }\n@keyframes drift { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }\n.thermos { border-top: 4px solid #fff; border-radius: 2px; }\n.handle.top {\n  border: 4px solid #fff; width: 60px; height: 20px;\n  position: relative; left: 50%; transform: translateX(-50%); border-radius: 2px;\n}\n.handle.top::after {\n  content: \"\"; display: block; width: 10px; height: 20px;\n  border: 2px solid #fff; position: absolute; left: 60%; top: 40%; border-radius: 4px;\n}\n","\u003Cdiv class=\"bubble-tea-container\">\n  \u003Cdiv class=\"beverage\">\n    \u003Cdiv class=\"handle top\">\u003C/div>\n    \u003Cdiv class=\"cup thermos\">\n      \u003Cdiv class=\"ingradients thermos-height\">\n        \u003Cdiv class=\"box\">\n          \u003Cdiv class=\"wave -one\">\u003C/div>\n          \u003Cdiv class=\"wave -two\">\u003C/div>\n          \u003Cdiv class=\"wave -three\">\u003C/div>\n        \u003C/div>\n        \u003Cdiv class=\"foam\" style=\"height: 10px;\">\u003C/div>\n        \u003Cdiv class=\"milk\" style=\"height: 25px;\">\u003C/div>\n        \u003Cdiv class=\"green-tea\" style=\"height: 25px;\">\u003C/div>\n        \u003Cdiv class=\"black-tea\" style=\"height: 0px;\">\u003C/div>\n        \u003Cdiv class=\"bubbles\">\u003C/div>\n        \u003Cdiv class=\"bubbles\">\u003C/div>\n        \u003Cdiv class=\"bubbles\">\u003C/div>\n        \u003Cdiv class=\"bubbles\">\u003C/div>\n        \u003Cdiv class=\"bubbles\">\u003C/div>\n      \u003C/div>\n    \u003C/div>\n  \u003C/div>\n  \u003Cp class=\"label\">四季奶青加珍珠\u003C/p>\n\u003C/div>\n",[],{},"/threads/cssart/bubble-tea",[],"2019-12-31",{"title":774,"description":779},"bubble-tea","threads/cssart/bubble-tea","Vue 3 互動式珍奶模擬器 — 調整奶蓋、牛奶、綠茶、紅茶、珍珠的比例，選擇你喜歡的杯型，調製屬於自己的一杯珍奶。",[767,819,820],"Vue 3","Interactive","xth75bDYQItZEPv6qNk6Xo9_cUylJLDTZ-9I1XXDU_Q",{"id":823,"title":824,"animated":7,"body":825,"client":34,"cover":34,"css_code":34,"description":31,"extension":35,"html_code":34,"images":853,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":854,"navigation":37,"order":34,"path":855,"photos":856,"published_at":857,"reading_time":34,"related":34,"role":34,"seo":858,"slug":859,"source_hash":34,"status":34,"stem":860,"summary":861,"tags":862,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":866,"__hash__":867},"threads/threads/articles/encounter.md","遇見",{"type":9,"value":826,"toc":851},[827,832,835,838,841,843,845,848],[12,828,829],{},[15,830,831],{},"演奏曲沒有歌詞，但是你聽得到。",[15,833,834],{},"聽見 冬天的離開\n我在某年某月醒過來\n我想 我等 我期待\n未來卻不能因此安排",[15,836,837],{},"陰天 傍晚 車窗外\n未來有一個人在等待\n向左 向右 向前看\n愛要拐幾個彎才來?",[15,839,840],{},"我遇見誰 會有怎樣的對白?\n我等的人 他在多遠的未來?\n我聽見風 來自地鐵和人海\n我排著隊 拿著愛的號碼牌",[15,842,837],{},[15,844,840],{},[15,846,847],{},"我往前飛 飛過一片時間海\n我們也曾在愛情裡受傷害\n我看著路 夢的入口有點窄\n我遇見你是最美麗的意外",[15,849,850],{},"總有一天 我的謎底會揭開",{"title":31,"searchDepth":32,"depth":32,"links":852},[],[],{},"/threads/articles/encounter",[],"2019-09-17",{"title":824,"description":31},"encounter","threads/articles/encounter","ukulele version",[863,864,865],"ukulele","fingerstyle","cover","https://www.youtube.com/watch?v=U5YBtGQbHu4","3Cgz4DxVBPf2Wl1pQbzJ_kn_9js9-k21Tos9RnixeC4",[869,885,931,1137,1167,1232],{"id":50,"title":51,"animated":7,"body":870,"client":34,"cover":66,"css_code":34,"description":56,"extension":35,"html_code":34,"images":880,"is_announcement":7,"is_pinned":37,"is_published":37,"key_points":34,"lang":34,"meta":881,"navigation":37,"order":34,"path":69,"photos":882,"published_at":71,"reading_time":34,"related":34,"role":34,"seo":883,"slug":73,"source_hash":34,"status":34,"stem":74,"summary":75,"tags":884,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":78},{"type":9,"value":871,"toc":878},[872,874],[15,873,56],{},[15,875,876],{},[60,877],{"alt":62,"src":63},{"title":31,"searchDepth":32,"depth":32,"links":879},[],[],{},[],{"title":51,"description":56},[],{"id":80,"title":81,"animated":7,"body":886,"client":34,"cover":34,"css_code":34,"description":86,"extension":35,"html_code":34,"images":926,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":927,"navigation":37,"order":34,"path":140,"photos":928,"published_at":142,"reading_time":34,"related":34,"role":34,"seo":929,"slug":144,"source_hash":34,"status":34,"stem":145,"summary":146,"tags":930,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":150},{"type":9,"value":887,"toc":924},[888,890,892,894,896,898,900,902,904,906,908,910,912,914,916,918,920,922],[15,889,86],{},[15,891,89],{},[15,893,92],{},[15,895,95],{},[15,897,98],{},[15,899,101],{},[15,901,104],{},[15,903,107],{},[15,905,110],{},[15,907,113],{},[15,909,116],{},[15,911,101],{},[15,913,121],{},[15,915,124],{},[15,917,127],{},[15,919,101],{},[15,921,132],{},[15,923,135],{},{"title":31,"searchDepth":32,"depth":32,"links":925},[],[],{},[],{"title":81,"description":86},[148,149],{"id":220,"title":221,"animated":7,"body":932,"client":34,"cover":548,"css_code":34,"description":549,"extension":35,"html_code":34,"images":1132,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":1133,"navigation":37,"order":34,"path":553,"photos":1134,"published_at":555,"reading_time":34,"related":34,"role":34,"seo":1135,"slug":557,"source_hash":34,"status":34,"stem":558,"summary":559,"tags":1136,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":563},{"type":9,"value":933,"toc":1123},[934,938,940,945,950,955,957,965,967,971,973,981,985,987,993,1001,1003,1007,1009,1011,1015,1019,1023,1025,1027,1029,1031,1035,1039,1041,1045,1047,1049,1051,1055,1057,1059,1061,1067,1071,1073,1077,1079,1083,1085,1089,1091,1093,1097,1099,1103,1105,1107,1111,1113,1115,1117,1121],[15,935,226,936,231],{},[228,937,230],{},[15,939,234],{},[15,941,237,942,243],{},[189,943,242],{"href":240,"rel":944},[193],[15,946,246,947,252],{},[189,948,251],{"href":249,"rel":949},[193],[15,951,255,952,261],{},[189,953,260],{"href":258,"rel":954},[193],[15,956,264],{},[266,958,959,961,963],{},[269,960,271],{},[269,962,274],{},[269,964,277],{},[15,966,280],{},[15,968,283,969,287],{},[228,970,286],{},[15,972,290],{},[292,974,975],{"className":294,"code":295,"language":296,"meta":31,"style":31},[298,976,977],{"__ignoreMap":31},[301,978,979],{"class":303,"line":304},[301,980,295],{},[12,982,983],{},[15,984,311],{},[15,986,314],{},[15,988,317,989,321,991,325],{},[228,990,320],{},[228,992,324],{},[292,994,995],{"className":294,"code":328,"language":296,"meta":31,"style":31},[298,996,997],{"__ignoreMap":31},[301,998,999],{"class":303,"line":304},[301,1000,328],{},[15,1002,337],{},[15,1004,340,1005,231],{},[228,1006,343],{},[15,1008,346],{},[348,1010,351],{"id":350},[15,1012,354,1013,358],{},[228,1014,357],{},[12,1016,1017],{},[15,1018,363],{},[15,1020,366,1021,370],{},[228,1022,369],{},[15,1024,373],{},[15,1026,376],{},[15,1028,379],{},[15,1030,382],{},[15,1032,385,1033,231],{},[228,1034,388],{},[15,1036,391,1037,395],{},[228,1038,394],{},[348,1040,399],{"id":398},[15,1042,402,1043,231],{},[228,1044,405],{},[15,1046,408],{},[15,1048,411],{},[15,1050,414],{},[15,1052,417,1053,421],{},[228,1054,420],{},[348,1056,425],{"id":424},[15,1058,428],{},[15,1060,431],{},[15,1062,434,1063,438,1065,442],{},[228,1064,437],{},[228,1066,441],{},[15,1068,445,1069,449],{},[228,1070,448],{},[348,1072,453],{"id":452},[15,1074,456,1075,460],{},[228,1076,459],{},[15,1078,463],{},[15,1080,466,1081,470],{},[228,1082,469],{},[15,1084,473],{},[12,1086,1087],{},[15,1088,478],{},[15,1090,481],{},[15,1092,484],{},[15,1094,487,1095,491],{},[228,1096,490],{},[348,1098,495],{"id":494},[15,1100,498,1101,502],{},[228,1102,501],{},[15,1104,505],{},[348,1106,509],{"id":508},[15,1108,512,1109,516],{},[228,1110,515],{},[15,1112,519],{},[348,1114,523],{"id":522},[15,1116,526],{},[15,1118,529,1119,533],{},[228,1120,532],{},[535,1122,537],{},{"title":31,"searchDepth":32,"depth":32,"links":1124},[1125,1126,1127,1128,1129,1130,1131],{"id":350,"depth":541,"text":351},{"id":398,"depth":541,"text":399},{"id":424,"depth":541,"text":425},{"id":452,"depth":541,"text":453},{"id":494,"depth":541,"text":495},{"id":508,"depth":541,"text":509},{"id":522,"depth":541,"text":523},[],{"readingTime":552},[],{"title":221,"description":549},[561,562],{"id":595,"title":596,"animated":7,"body":1138,"client":34,"cover":630,"css_code":34,"description":601,"extension":35,"html_code":34,"images":1162,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":1163,"navigation":37,"order":34,"path":633,"photos":1164,"published_at":635,"reading_time":34,"related":34,"role":34,"seo":1165,"slug":637,"source_hash":34,"status":34,"stem":638,"summary":639,"tags":1166,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":643},{"type":9,"value":1139,"toc":1160},[1140,1142,1144,1146,1150,1152,1154,1156],[15,1141,601],{},[15,1143,604],{},[15,1145,607],{},[15,1147,610,1148,231],{},[228,1149,613],{},[15,1151,616],{},[15,1153,619],{},[15,1155,622],{},[12,1157,1158],{},[15,1159,627],{},{"title":31,"searchDepth":32,"depth":32,"links":1161},[],[],{"readingTime":552},[],{"title":596,"description":601},[641,642],{"id":645,"title":646,"animated":7,"body":1168,"client":34,"cover":736,"css_code":34,"description":31,"extension":35,"html_code":34,"images":1227,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":1228,"navigation":37,"order":34,"path":739,"photos":1229,"published_at":741,"reading_time":34,"related":34,"role":34,"seo":1230,"slug":743,"source_hash":34,"status":34,"stem":744,"summary":745,"tags":1231,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":34,"__hash__":747},{"type":9,"value":1169,"toc":1225},[1170,1174,1176,1178,1180,1182,1184,1188,1190,1192,1194,1196,1198,1200,1204,1212,1217],[12,1171,1172],{},[15,1173,653],{},[15,1175,656],{},[15,1177,659],{},[15,1179,662],{},[15,1181,665],{},[15,1183,668],{},[15,1185,671,1186,675],{},[298,1187,674],{},[15,1189,678],{},[15,1191,681],{},[15,1193,684],{},[15,1195,687],{},[15,1197,690],{},[15,1199,693],{},[12,1201,1202],{},[15,1203,698],{},[15,1205,701,1206,705,1208,709,1210,713],{},[228,1207,704],{},[228,1209,708],{},[228,1211,712],{},[15,1213,716,1214],{},[189,1215,719],{"href":719,"rel":1216},[193],[15,1218,723,1219,729,1222],{},[189,1220,728],{"href":726,"rel":1221},[193],[189,1223,732],{"href":732,"rel":1224},[193],{"title":31,"searchDepth":32,"depth":32,"links":1226},[],[],{"readingTime":552},[],{"title":646,"description":31},[],{"id":823,"title":824,"animated":7,"body":1233,"client":34,"cover":34,"css_code":34,"description":31,"extension":35,"html_code":34,"images":1255,"is_announcement":7,"is_pinned":7,"is_published":37,"key_points":34,"lang":34,"meta":1256,"navigation":37,"order":34,"path":855,"photos":1257,"published_at":857,"reading_time":34,"related":34,"role":34,"seo":1258,"slug":859,"source_hash":34,"status":34,"stem":860,"summary":861,"tags":1259,"tech_stack":34,"translation_of":34,"type":77,"url":34,"video_url":866,"__hash__":867},{"type":9,"value":1234,"toc":1253},[1235,1239,1241,1243,1245,1247,1249,1251],[12,1236,1237],{},[15,1238,831],{},[15,1240,834],{},[15,1242,837],{},[15,1244,840],{},[15,1246,837],{},[15,1248,840],{},[15,1250,847],{},[15,1252,850],{},{"title":31,"searchDepth":32,"depth":32,"links":1254},[],[],{},[],{"title":824,"description":31},[863,864,865],{"generatedAt":1261,"author":1262,"articles":1291,"products":1313,"projects":1316,"pages":1317,"cssarts":1319},"2026-07-01T17:21:19.511Z",{"name":1263,"handle":1264,"location":1265,"status":211,"statusText":1266,"quote":1267,"bio":1268,"featuredLink":1272,"links":1273,"site":1288},"徐可可","ivanhsu","Taipei, Taiwan","踊る暇があったら発明して","寫 Code 算是文字工作者嗎？🤔",[1269,1270,1271],"用剛剛好的 Tech Stack 開發實用的生活小物 SaaS。👨🏻‍💻","```npm i inspiration && npm run dev```","看到好吃的 Reels？分享給我，幫你摘要店家清單 👇🏻","https://reelly.life/u/ivanhsu.co/tenjin-shinya-shokudou",[1274,1277,1279,1282,1285],{"type":1275,"url":1276},"email","ivanhsu.ship@gmail.com",{"type":1278,"url":191},"website",{"type":1280,"url":1281},"github","https://github.com/ivan19940106",{"type":1283,"url":1284},"twitter","https://twitter.com/ivanhsuu",{"type":1286,"url":1287},"instagram","https://www.instagram.com/ivanhsu.co",{"name":1263,"url":1289,"description":1290},"https://ivanhsu.co","千里の道も一歩から。",[1292,1295,1299,1302,1306,1309],{"title":596,"slug":637,"publishedAt":635,"tags":1293,"excerpt":639,"keyPoints":1294,"cover":630},[641,642],[],{"title":81,"slug":144,"publishedAt":1296,"tags":1297,"excerpt":146,"keyPoints":1298},"2025-12-31T00:00:00.000Z",[148,149],[],{"title":646,"slug":743,"publishedAt":741,"tags":1300,"excerpt":745,"keyPoints":1301,"cover":736},[],[],{"title":824,"slug":859,"publishedAt":1303,"tags":1304,"excerpt":861,"keyPoints":1305,"videoUrl":866},"2019-09-17T00:00:00.000Z",[863,864,865],[],{"title":221,"slug":557,"publishedAt":555,"tags":1307,"excerpt":559,"keyPoints":1308,"cover":548},[561,562],[],{"title":51,"slug":73,"publishedAt":1310,"tags":1311,"excerpt":75,"keyPoints":1312,"cover":66},"2026-06-13T00:00:00.000Z",[],[],[1314],{"title":153,"slug":210,"excerpt":213,"tags":1315,"url":191,"status":211},[215,216,203],[],[1318],{"title":6,"slug":43,"excerpt":45},[1320,1321],{"title":774,"slug":815},{"title":750,"slug":763},1782926519923]