この記事は弁護士ドットコム Advent Calendar 2020、11日目の記事です。
こんにちは、弁護士ドットコムのフロントエンドエンジニア たか( @happylifetaka )です。
昨日は、@koriym さんの「メディアタイプとALPSプロファイル」でした。
ドメイン固有のメディアタイプ、プロファイルのどちらも詳しく説明されています。👀
さて、フロントエンドエンジニアチームは毎週Javascript関連のプチ勉強会をしています。今回はそのプチ勉強会で使用した「VueUseについて調べてみました」の記事を紹介します。
実は、Qiitaに初投稿ですのでお手柔らかによろしくお願いいたします。
VueUseとは?
VueUseとは、react-use( https://github.com/streamich/react-use )にインスパイアされたVueのComposition API集です。
以下の特徴があります。 (公式サイトより)
- 依存関係0なので、バンドルのサイズは心配なし
- Fully tree shakable(不要な部分を除去してバンドルしてくれる)
- Typescriptで記述されている
- Vue Demiを使用しており、Vue3,Vue2のどちらもサポート
- StoryBookで、インタラクティブなドキュメントとデモを掲載
- CDNを介しての使用可
- オプションアドオンとしてFirebase、vue-i18nをサポート
- MITライセンス
example(サンプルコード)
マウスの座標とユーザーがダークモードを使用しているかどうか。
import { useMouse, usePreferredDark, useLocalStorage } from '@vueuse/core'
new Vue({
setup() {
// ユーザーのマウスの座標を取得します。
const { x, y } = useMouse()
// ユーザーがダークモードを使用しているか取得します。
const isDark = usePreferredDark()
return { x, y, isDark }
}
})
サンプル(CODEPEN)
CODEPEN で書きましたが、公式のstorybook でdemoを実行できるので、そちらを見ればOKです。
どんなことができるの?
いろんなことができます。具体的には以下です。(流し見推奨)
アニメーション関係
-
useInterval一定ms秒ごとに増加するカウンタ
const { counter } = useInterval(200)
-
useIntervalFnsetIntervalをラッピングしたもの
const { start, stop } = useIntervalFn(() => {
counter.value++ }, 1000)
-
useNow現在のタイムスタンプを返してくれる
const now = useNow()
-
useRafrequestAnimationFrameの反応経過時間を返してくれる
const elapsed = useRaf()
-
useRafFnrequestAnimationFrameの反応経過時間ごとに実行する関数を作る
useRafFn((elapsed) => {
console.log(elapsed.value)
})
-
useTimeout一定時間後に処理を実行(startがtrueになる)
const { ready, start } = useTimeout(1000)
-
useTimeoutFnuseTimeoutの関数版
const { ready, start } = useTimeoutFn(() => {
console.log('Fired!')
}, 3000)
-
useTransition様々なトランジションの変化に掛かる時間を取得する- トランジションって何って方はこちらを参照
ブラウザ関係
-
useBrowserLocationbrowser location(hostname...etc)を取得する。 -
useClipboardクリップボードの設定・取得をする。(とあるがChrome上で、公式のStorybookでは取得が同一画面でしか動かない。) -
useCssVar要素のCssを操作する。 -
useEventListenerイベントリスナーを設定する。(addEventListenerのラッピング、removeも自動でしてくれる) -
useFullscreenフルスクリーンかを取得する。またフルスクリーンと解除の関数も取得。 -
useMediaQuery大きな画面かとダークモードかを取得する。
const isLargeScreen = useMediaQuery('(min-width: 1024px)')
-
usePermission位置情報、マイク、カメラ、MIDIのパーミッションを取得する。 -
usePreferredColorSchemeダークモードかライトモードか指定なしかを取得する。 -
usePreferredDarkダークモードか取得する。 -
usePreferredLanguagesブラウザの優先言語を取得する。 -
useShareWeb Share APIを呼び出してシェアを行う(Safariとスマホのブラウザでしか動作しない) - 感知(センサー)関係
-
useBatteryバッテリーの状態(%,充電中かなど) -
useDeviceLight光センサーの明るさを取得する -
useDeviceMotionモーションセンサーの数値を取得 -
useDeviceOrientationデバイスの物理的方向を取得する(スマホ向け) -
useDocumentVisibilityブラウザを最小化やタブで切り替えて離れてから戻ったかを取得する。 -
useElementVisibility要素がviewport内に入ってるかを取得する -
useGeolocationGeolocation APIを使って位置情報を取得する -
useMouseマウスの座標取得する。 -
useMouseInElement要素内のマウスの座標を詳細で取得する。 -
useNetworkネットワークの状態(オンライン、ダウンロード速度、3Gや4Gなど)を取得する。 -
useOnlineオンラインかどうかを取得する -
usePageLeaveページをはなれたかどうか取得する -
useParallax視差(パララックス)効果を作成する。 -
useWindowScrollウィンドウのスクロール位置を取得する。 -
useWindowSizeウィンドウサイズを取得する。
State(状態)関係
-
createGlobalStateVueインスタンス全体で利用できるStateを作成する -
useAsyncStateブロッキングされない非同期のstateを作成する。(例:ajaxなどの読み込みが終わったら反映される) -
useCounterカウンターを取得、設定する。 -
useIdleユーザーが一定時間非アクティブかを取得する。 -
useLocalStorageLocalStorageの値を取得する -
useSessionStorageSessionStorage. の値を取得する -
useStorageLocalStorage/SessionStorageに値を設定したり取得する -
useStoragePlain非推奨 useStorageを使ってください。(多分旧ライブラリ?)
Side Effect(副作用)関係
-
useDebounce一定時間後に引数に指定されたrefを返す。(一定時間後に検索とかで便利そう。)
const input = ref('');
const debounced = useDebounce(input, 1000);
-
useDebounceFnuseDebounceの関数版 -
useThrottle(入力されて変化があっても)一定時間毎しかrefを返さない。
(例:1000ms秒の間に入力値が変化してもrefが返るのは1回) -
useThrottleFnuseThrottleの関数版
その他
-
useWebSocketwebSocketに接続してデータを取得と送信を行う -
useWebWorkerWeb Workers に接続してデータの取得と送信を行う。 -
useWebWorkerFnUIをブロッキングしない処理を実行するworkerを作る。
アドオン関係
-
FirebaseFirebaseのFirestoreとRTDBから取得ができる(ローカルデータとリモートデータベースの同期を常に維持することは簡単との説明あるがおそらく書き込みはできない) -
vue-i18n多言語対応のライブラリi18nをラッピングしたもの。
所感
- バンドルファイルがない、Vue3,Vue2の両方とも対応しているのは素晴らしい。
- リアクティブに値を取得(や設定)できるのは便利。
- ライブラリの使用が想像以上に簡単。
- 多くの機能がありいろんなことができる。一部用途がニッチな機能もあるが、個人開発とかプロトタイプ作成でも使いやすそう。
- 基本的にブラウザのAPIをラッピングしてるもので、IEとか特定のブラウザで動かないものもある。
- ソースは読みやすいものも多いので気になる機能があればソースを読みに行き実装方法を知るのも手。
クラウドサイン でのVue.js状況について
VueUse は使用していないですがクラウドサインではVue.jsを使用しています。
しかし、レガシーなコードもあり徐々にjQueryからVue.jsへ移行作業を進めています。
興味がある方は以下へ。
Vue.js経験者求む!クラウドサインのモダン化をリードしてください!
https://www.wantedly.com/projects/538325
12/12はPHPCon(Vue.jsではないですが…)
実は、PHPカンファレンスのスタッフもしているので少し宣伝です。
PHPカンファレンス2020が今年はオンライン開催で2020/12/12の明日開催です。
参加費は無料ですので、興味ある方は是非。
https://phpcon.php.gr.jp/2020/
明日(12/12)の記事は…
明日(12/12)の記事は、 @michimani さんの「AWS CLI のみで何か構築する話」です。お楽しみに。