發表文章

目前顯示的是有「React」標籤的文章

[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...

[React] react 使用 Google Analytics - 追蹤 button、select

圖片
react 使用 Google Analytics (以下簡稱GA), 你也可以不使用套件,直接使用GA上提供的「全域網站代碼(gtag.js)」 1.安裝 GA 套件 2.初始化 GA 3.將 url 加入 GA 4.將 button 加入 GA 5.將 select 加入 GA 6.將其寫成 component 置於 src/index.js 1.安裝 GA 套件 npm i react-ga4 2.初始化 GA import ReactGA from 'react-ga4' ReactGA.initialize('G-XXXXXXXXXX') //你的GA評估ID 3.將 url 加入 GA ReactGA.send('https://www.xxx.xxx') //你要偵測的URL 理論上加完,並執行該網頁,就會在GA平台上看到如下的狀況 4.將 button 加入 GA const gaEventTrack = () => { // body 外無 hasAttribute 方法,避免錯誤 const body = document.querySelector('body'); body.addEventListener('click', (e) => { let target = e.target; // 查找元素不包含 data-ga-action,且到 BODY 後跳出 while(target.hasAttribute('data-ga-action') === false && target.tagName !== 'BODY'){ // 父元素覆寫當下元素 target = target.parentNode; } if(target.hasAttribute('data-ga-action')){ const dataGaCategory = target.getAttrib...

[React] SASS(SCSS) 環境設定 (CRA用)

圖片
1. 安裝 sass 2. 修改副檔名 3. 引入該檔案 1. 安裝 sass 有人可能會問說,node-sass 不行嗎? 是可以,不過可能會遇到些 問題 ,且已經不支持,請改裝 sass 移至 react 專案,安裝 sass cd my-app npm i sass (or yarn add sass) 2. 修改副檔名 .css 改為 .scss 3. 引入該檔案 視自己的 .scss 檔名及路徑來修改,引入後即可使用 import "./index.scss"

[React] react-router-dom(react-router) 基本路由用法

圖片
忘就忘了 只能繼續記.. 1. react-router-dom 安裝 2. 路由基本使用 3. <Switch> 用此來選擇正確地點 1. react-router-dom 安裝 移動至 react 專案,在其目錄下安裝 cd my-app npm react-router-dom (or yarn add react-router-dom) 2. 路由基本使用 引入 react-router-dom、網頁 元件 import { BrowserRouter, Route } from 'react-router-dom'; import Home from './pages/Home'; import About from './pages/About'; 把路由語法寫上基本上就能使用 <BrowserRouter> <Route path="/about/home"> <Home /> </Route> <Route path="/about"> <About /> </Route> </BrowserRouter> 如果不知道現在在操作甚麼的話.. 請點此參考... 執行結果如下,但也可以看出問題,所以必須搭配 <Switch> 3. <Switch> 用此來選擇正確地點 引入 <Switch> 元件 import { BrowserRouter, Route, Switch } from 'react-router-dom'; <Swicth> 寫上去即完成 <BrowserRouter> <Switch> <Route path="/about/home"> <Home /> </Route> <Route path="/about...

[React] 快速建立 react 專案,透過 CRA

圖片
 這.. 建立一次後.. 就是一直 coding.. 是我的話.. 不會記得... 1. 下指令建專案 (基本上這樣就可以了..) 2. 刪除不需要之檔案 3. 建立基本結構 (yijay 常用之結構..) 4. 測試專案 1. 下指令建專案 要先安裝 Node (10.16↑) 環境 及 npm (5.6↑) 套件管理器 在指定的資料夾下以下指令:npx create-react-app my-app 下完即開始安裝 安裝完成 移動到該資料夾:cd my-app 執行程式:yarn start (如果僅裝 npm,那請下 npm start 來執行) 以下畫面即完成安裝 2. 刪除不需要之檔案 有些東西未來有可能還是會用到,但 yijay 還很新.. src 資料夾的東西刪了很多,保留 index.js 即可 修改 index.js,理論上執行畫面就不會報錯了 3. 建立基本結構 此結構,因人而異,因公司而異,沒有一定 (押韻!!) components:各頁面之元件 global:常數、小工具等共用之程式 pages:各頁面 styles:css 檔 4. 測試專案 在 pages/home/index.js coding 在 src/index.js 把 home 引入進來 測試成功.. 感動 :))

[JavaScript] fetch、ajax、axios 基本用法(前後端溝通、串接API)

圖片
記錄一下.. 面試或工作、 前後端溝通 上 (一般 HTML 或 React、Node.js) 都常用到.. 我個人是比較喜歡用 axios ~ 股票 API (JSON 格式): https://www.twse.com.tw/exchangeReport/STOCK_DAY?response=json&date=20210702&stockNo=2330 會看到這樣的資料 (json) 如果以上不能用,可以使用這位大哥的 API (text 格式):https://script.google.com/macros/s/AKfycbw5PnzwybI_VoZaHz65TpA5DYuLkxIF-HUGjJ6jRTOje0E6bVo/exec?name=${name}&age=${age} 會看到這樣的資料 (text) 程式撈取結果大概會長這樣 fetch: 1. promise based (可改為 async/await) 2. HTML5 API let btn = document.querySelector('.btn'); btn.addEventListener('click', () => { fetch('https://www.twse.com.tw/exchangeReport/STOCK_DAY?response=json&date=20210702&stockNo=2330', { method: 'GET', }) .then((response) => { return response.json(); }) .then((result) => { console.log(result); }); }); ajax: 1. xhr based 2. 須引用 jQuery $('.btn').on('click', () => { $.ajax({ ...