Arkhi.js - 基於島嶼架構的前端框架
「Arkhi」一詞源自群島(Archipelagos)語源「Arhki」(意味 Chief)和「pelagos」(意味 Sea)。我們利用島嶼架構的設計,協助開發者們規劃出一個個「互動性的小島」,輕鬆建立輕量、快速的網站。
Demo: (WIP)
安裝 Installation
npx create-arkhi@latest my-app
cd my-app
npm i # pnpm, yarn, bun
Getting Started
建立島嶼
import { useState } from "react";
import { Island } from "arkhi/client";
const Counter = ({...props}) => {
const [state, setState] = useState();
return (
<button onClick={()=>setState(state+1)} {...props}>
{state}
</button>
);
}
const CounterIsland = Island(Counter);
export default function Page() {
return (
<>
<div>
靜態: <Counter />
</div>
<div>
動態: <CounterIsland />
</div>
</>
);
}
透過島嶼 HOC 包裹住,我們將範例中第二個 Counter 標記為島嶼,在客戶端載入時渲染。而第一個 Counter 因為沒有包裹住,所以在客戶端會保持靜態。
須注意一定要加上 {...props}
,Island 才能夠標記島嶼。
分享狀態
import { Share, useShare } from "arkhi/client";
export data = new Share<string>("init data");
export function Foo() {
const share = useShare(data);
return (
<button onClick={() => data.data+=1 }>
Click { share }
</button>
);
}
由於在不同的島嶼之間無法共享狀態,我們使用 Share API 解決這個問題。useShare()
會在資料更新時自動提醒所有訂閱資料的島嶼重新選染,達到跨島嶼共享狀態。
島嶼架構
島嶼架構指的是在客戶端針對需要互動性的地方進行渲染,以降低載入時間與提高運作效率的設計。對比渲染整個頁面,在島嶼架構珠我們只會針對性的對需要互動性的部份進行 hydration,並且讓多數的界面保持靜止。