慢慢更新中
1. Dynamic component
React — Dynamic Component Names with JSX
Dispatching an Action to Show the Modal
Month: May 2021
進行中的練習專案/課程
styled-component 顯示 className in Create React App
- 安裝react-app-rewired
- 安裝react-app-rewire-styled-components
- 新增一個config-overrides.js檔案,內容參照2的寫法
- 在package.json的start做修改:
“start”: “react-app-rewired start”, - 大公告成!!
邪魔歪道的isNaN
data:image/s3,"s3://crabby-images/d5541/d5541132695a79fdd06bfbfbec57dc001836fb81" alt=""
中山區uberEats、foodPanda心得
怪獸小雞排,農安店
還蠻好吃的,但我要減肥,下次不考慮點。
覺得雞排我吃不飽,豆腐也少少的QQ
雞排的皮脆脆的很好看,蒜片大顆,也不錯吃,四季豆也好吃,
算是吃口味的吧,但對我來說CP值不高
data:image/s3,"s3://crabby-images/f3d3f/f3d3f8aaf6c3b0ebacfa6e3dadf4a61b1c44d4f2" alt=""
點了牛肉咖哩,還蠻好吃,但吃一個便當吃不飽,感覺要多點一些的
data:image/s3,"s3://crabby-images/facfb/facfb83b58e1c8ca57be10272096876e5b2853ee" alt=""
還不錯吃,這家店…意外好吃的健康便當,那個起司雞我本來以為會很噁心,沒想到蠻好吃的。應該是有點焗烤的感覺。
專案心得
要全選按鈕的check的值就用
selectedItems.length === tablelist.length
來比較
- state還是儘量用global比較好…這樣假設要重置資料,如果它沒有unmount,local state在dispatch的function裡面要重置很麻煩。又多了一個地方要維護這樣…
- 一個專案做很久了,有的商業邏輯會忘記,最好還是記個筆記放在專案上
而且我覺得圖文的筆記比較好,文字記錄還是比較難懂 - 每個專案不同port也應該做一個紀錄,不然一次開兩個的話會搞混。
- 考慮要不要加TypeScript,讓每次讀code可以輕鬆一點
- 要清除redux state的時候要用clearCity() 還是直接setCity(null) ?
覺得用一樣的function好了,不然要找在哪裡cleanup很麻煩 - 要清除local state和redux的state避免下次點進來看到一樣的,要在哪個component上寫useEffect的cleanup 還是在redux的方法之類?
- redux的值也要知道它會是什麼值,不它用 list obj來分?==
- 在打compare的API的時候,是不是前端先確認它有沒有改變,沒有改的話就不切換畫面給它?不然會出現空table,很醜…
- 每個component如果有用到依賴redux的預設值,在切換tab的時候注意一下,有可能redux的值還沒有更新,但component已經render完了,但它抓到的值還是上次redux的值(例如共用一個input…)這時候可以用useEffect來讓它做refresh
useEffect(() => {
if (!singlePay) {
setInput(“”)
setIsValid(false);
}
}, [singlePay])
這個singlePay雖然有給它更新值,但元件沒有跟著更新..@@ - 相關的邏輯放在同一個component,越往下child放越好避免上面rerender
Google Analytics教學
data:image/s3,"s3://crabby-images/2bae0/2bae0868fbbb7e2bb6437922d45e2d14ef27e106" alt=""
.一開始接好之後,需要等24小時才會有資料
首先要建立自己的GA帳號,也要定一個property。
data:image/s3,"s3://crabby-images/b7362/b736242b78000a186bc959b996caceab9f859b72" alt=""
A property represents a business’s web and/or app data. An account can contain one or more properties.
之後點一點就開通帳號,還蠻簡單的。
data:image/s3,"s3://crabby-images/bb217/bb2176a57f8ae683c33e1aec6aea287b2664bad7" alt=""
data:image/s3,"s3://crabby-images/ed09f/ed09f53bf5f3e16f6ffa9f1c68007a06d98221a4" alt=""
選了一個platform,它會給你MEASUREMENT ID
data:image/s3,"s3://crabby-images/5bfbd/5bfbdec55b902538be58660e0517788aa1361adb" alt=""
data:image/s3,"s3://crabby-images/364a2/364a2330ae06941da0482eb9d33462fcde60eee8" alt=""
一開始記得先publish
data:image/s3,"s3://crabby-images/2c8e3/2c8e39c5d4787373bcbde0df1e2cc5d3dad4ef3f" alt=""
data:image/s3,"s3://crabby-images/d1b7d/d1b7d06a9fc04c03eb567c5d8f37e4e69c43c532" alt=""
data:image/s3,"s3://crabby-images/2dc2b/2dc2b2b0b8c254fcb7b0101a78bb87067db8087d" alt=""
data:image/s3,"s3://crabby-images/5ef7b/5ef7b886733da48fe8f7baa1acbe70a5d47c2a2f" alt=""
data:image/s3,"s3://crabby-images/c9c22/c9c221d69fefdfa29f03ccf05e9901ea14696761" alt=""
有加tag或是更新,記得要publish,不然加了tag也沒有用
更新telegram的網站preview
@webpagebot 點它更新preview
Unnecessary Re-renders
用這個放在背景圖,可以知道元件有沒有re-render
const randomColour = () => '#'+(Math.random()*0xFFFFFF<<0).toString(16);
style={{background: randomColour()}}
default parameter in destructuring
data:image/s3,"s3://crabby-images/80f66/80f665e812a42a0fd659ca7bfb08c68d74930b21" alt=""
在設計hooks的時候,想要不用帶參數也不會整組壞掉(因為有時候api還沒接),用這個語法很實用