發表文章

[生活] 得了新冠肺炎(武漢肺炎)之受虐日

不得不說,這病對我來說很痛苦,搞得身心靈都受創,原本約好的活動全部一概取消 囧orz... 傳染力 這邊不是什麼專業分析,只是想統計一下,一間辦公室,消失(發病)人數漸漸上升的情況 第一天:1人 第二天:3人 第三天:7人 第四天:12人 第五天:18人 因辦公室內約30人,後續就大概到 20 幾人就停了,不過這數字就等於說,一個空間內大概7成的人都會被傳染到,可見這傳染力道多可怕.. 發病第一天 這真的記憶猶新啊.. 中午依舊吃著舒服的午餐,但就是覺得身體哪邊小小怪,回到辦公室後,MD 有夠冷,穿再多還是冷,然後關節開始莫名覺得痠,以為只是錯覺,但那天剛好要尾牙,所以我這就收到了一組快篩,不過驗出來是一條,我就還是去了 但傍晚開始,我的腰就一直很痠,痠到難以控制,我就只好外出到附近中醫看一下,但裡面的人是建議說先去看西醫比較好,所以我就離開,不過那天也晚了,就只能先買個普拿疼之類的要擋一下,隔天再去看 症狀: 1. 腰痠,痠爛 2. 肌肉、關節處痠 3. 很冷(當天2X度) 發病第二天 這天快篩終於驗出來,也開始了五天的隔離旅程(感覺會很艱辛) 因為知道要隔離,所以就先買了些菜、肉、水、寶礦力、水果,怕會餓死就先買起來 症狀: 1. 發燒(39度多) 2. 頭痛、頭昏 3. 畏寒 發病第三天 真的很不舒服,一直躺著,身體又一直忽冷忽熱,有時熱到整個冒大汗,有時又冷到心臟不舒服 而昨天買的食物,「完全」不想吃,也不想用...,變成都看 uber eat 來找飯吃 症狀: 1. 發燒(38 - 39度多) 2. 頭痛、頭昏 3. 喉嚨微痛 發病第四天 持續躺... 症狀: 1. 發燒(37 - 38度多) 2. 喉嚨痛炸,吞口水就要殺人 3. 痰很多,多到覺得會被噎死 發病第五天 持續躺... 症狀: 1. 喉嚨痛炸 2. 痰很多 3. 流鼻水、打噴嚏、鼻塞 發病第六天 這天也終於舒坦了一些,也可以出門了... 症狀: 1. 喉嚨微痛 2. 痰變少

[理財] 台新金 現金增資發行己種交換特別股繳款書

圖片
Hi,本人為台新金的小小小小........小戶 近期收到一封信,信中標題寫著「111年現金增資發行己種交換特別股繳款書」,照片如下 我呢,當下看到以為我是台新的「特別戶」,是不是有什麼優惠好康的!!!! 想說他們增資我可以免費拿到 10 股,雖然很少,但還是有!!! 但怎麼看都覺得不對,一直說什麼繳款啥鬼,我還是覺得很好奇到底安怎,而且就只有到 7/13,所以我就到台北的台新銀行詢問一番 結果........ 營業員表示:「你就是買了 550 股,需要繳款」 我當下聽到就不想聽了,看來那位營業員完全不懂.... 後來有他們的經理經過,我就說我要問他 經理表示:「你先到那邊的證券專櫃等我」 我心想:「水啦,有結果了」 經理結果說:「我幫你打一下客服」 我...... 好... 我等... 結果:「無結論」 我 OOXX 最後......... 我找到一位好像專門理財的營業員詢問了一下,終於有答案啦 他就說「就是他們銀行有在做現金增資,問我要不要繳款買這些股」 後來我是覺得不合邏輯,因為 1 股要價 17.65,現在股價都已經跌到 15.XX,怎麼想邏輯都很不對 最後私下表示... 「你懂就好」 所以啊........ 我根本不是什麼特別戶 囧 orz...... 本人「不會繳款」,因為完全就是「買貴」,所以要買的人直接去股市裡面買就好,還比較划算... 

[javascript] 雙問號運算子 nullish coalescing operator

圖片
?? (nullish coalescing operator) 用法 // pseudocode,大概示意,非完整 code const items = ["abc", "", 123, 0, true, false, null, undefined]; {items.map(item => { return ( {`${item} ?? '找不到 item'`} ); })} 結果圖 情境 有一個 data 回傳值如下,且 true、false 在程式內都可能用到 data: { isTeacher: false } 如果預設值為 false,那使用 || 或是 ?? 都是沒有問題 data.isTeacher || false //output: false data.isTeacher ?? false //output: false 但如果預設值為 true,那這時候使用 ?? 才會正確,或是用 || 並配合額外處理的 code data.isTeacher || true //output: true data.isTeacher ?? true //output: false || (or operator) 用法 // pseudocode,大概示意,非完整 code const items = ["abc", "", 123, 0, true, false, null, undefined]; {items.map(item => { return ( {`${item} || '找不到 item'`} ); })} 結果圖 情境 || 就大部分情況都在使用,像回傳值為 undefined,就直接使用「 data.count || 0 」,就能得到 0 此預設值。

[React] next.js CSR, SSR, SSG 簡單實作 implement

一、CSR import { useEffect, useState } from 'react'; interface Post { userId: number, id: number, title: string, body: string, } const Home = () => { const [post, setPost] = useState<Post>(); useEffect(() => { fetch('https://jsonplaceholder.typicode.com/posts/1') .then((res) => res.json()) .then((res) => setPost(res)); }, []); return ( <div> <h1>{post?.title}</h1> <p>{post?.body}</p> </div> ) } export default Home 二、SSR import type { GetServerSideProps } from 'next' interface Post { userId: number, id: number, title: string, body: string, } interface HomeProps { post: Post, } const Home = ({ post }: HomeProps) => { return ( <div> <h1>{post.title}</h1> <p>{post.body}</p> </div> ) } export default Home export const getServerSideProps: GetServerSideProps = async ()

[React] SPA,前後端分離,到底該如何動態修改 meta tag ?

概述 How to update meta-tag in react? 這問題想必前端工程師都有碰過,但這邊先告訴大家,想透過「純前端」修改... 「不可能」...!! 為什麼? Google 搜尋引擎在爬文的時候,透過 javascript 產出來的標籤是無法爬到。 像現在有使用 react、vue、angular 等等這類的框架,這種 SPA、前後端分離的程式架構,都是透過 javascript render 出來的網頁,因此 SEO 肯定受限十足。 又有人可能會說,Google 搜尋引擎已經可以爬 javascript 產生的 tag,確實現在框架的盛行,Google 勢必還是得對這做處理,畢竟他們的網站也是有使用框架來進行。 問題 那 Google 都能爬 javascript 產生的 tag 現在還會有什麼問題呢? 「動態產生 meta tag」 這部分並非透過前端就能「完美」達到。 怎麼說? 透過動態產生出來的,那網址剪下貼至 FB、Line 等等之類的,都會無法顯示那些 tag,那 SEO 上勢必還是打折了。 解決 相信很多人一定都有找了很多解法,以下就列出幾個解法供參考 (X) 1. react-helmet (X) 2. react-helmet-async (X) 3. react-super-seo (O) 4. next.js (O) 5. remix (O) 6. environment variable (env) 從以上可以看出 javascript 前端方式處理得仍無法解決,必定要透過 SSR 的方式,或是環境變數來處理。

[React] 動態修改 meta-tag 解決 SEO,透過 env(environment variable)

圖片
概述 update meta-tag in react 正確的動態解決 meta-tag 方式,透過 env。 沒有裝 next.js 的專案可以用這招。 嘗試過 react-helmet 無效者也請用這招。 流程 1. get data in node.js -> 2. set env to index.html -> 3. build and test -> 4. success! 1. get data in node.js 純前端者,不要看到後端就跑,這邊只是寫一點點,沒很多 建立 script.js // const fs = require('fs'); // const pathConfig = './config.json'; // const config = JSON.parse(fs.readFileSync(pathConfig)); // const title = config.title; // const description = config.description; const execSync = require('child_process').execSync; const title = 'EJ的網站標題'; const description = 'EJ的網站描述'; const favicon = 'https://firebasestorage.googleapis.com/v0/b/deploy-for-chien313jay-test.appspot.com/o/images%2Ffavicon.ico?alt=media&token=d019d820-16a3-45fd-b5e5-15b8aa355ea8'; execSync(`VITE_APP_TITLE="${title}" VITE_APP_DESCRIPTION="${description}" VITE_APP_FAVICON="${favicon}" CI=false npm run dev`); 這樣就把 env 寫至你的

[React] 安裝 vite 及 react 發佈至個人 github page

圖片
「想讓全世界看到我的網頁」,那就來把 react 上到 github page 吧! 1. 透過 vite 快速安裝 react (比 webpack 快,比 CRA 瘦) 2. 安裝 gh-pages 來快速發佈至 github page 3. 修改 base path 完成發佈 1. 透過 vite 快速安裝 react 這邊會建立一個「home」資料夾,並快速安裝 react yarn create vite home --template react 如果沒裝 yarn 也可以使用 npm 來安裝 npm create vite@lateset home -- --template react 裝好 vite 接著在來把依賴套件裝起來 yarn install 那我們可以先看看資料夾內容,應該差不多,不過接著的 HMR 及運行速度才是重點 vite、react 那就來試用看看這個 vite build tool run 起來 react 的狀況吧! yarn dev 我這邊是 0.3s 就運行起來,然後自己嘗試更改一些程式可以發現 HMR 快得驚人 ... http://localhost:3000/ 2. 安裝 gh-pages 來快速發佈至 github page 我們先連接至自己 github 上的 repository,並把專案推上去 git init git branch -M main git add . git commit -m 'first commit' git remote add origin https://github.com/你的帳號/你的repo.git git push -u ori