3
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

新時代はAlpine.jsだ~世界中全部(Alpine.jsに)変えてしまえば~↑↑Advent Calendar 2022

Day 9

Alpine.jsで非表示の要素(モーダルなど)が読み込み時に一瞬表示されてしまう時の対処法

Last updated at Posted at 2022-12-09

この記事で解決できること

例えばこういう場面

x-dataで{ open:false }をデフォルトで設定しといて、ボタンをクリックしたら{ open: true }にして表示させよう!

<button x-data={ 
    open: false, 
    toggleOpen(){ open = ! open }
    }>

<div x-show="open">やっほー</div>

↑ボタンクリックしたら「やっほー」が表示されるコード

上手くいってそうですがこのコードだとブラウザで読み込み時に一瞬だけ「やっほー」が表示されてしまいます。

これは"Blip"と呼ばれる現象です。
HTMLがAlpine.jsより先に読み込まれることにより、x-showの要素が表示されてしまう現象です。

要はこういうこと

image.png

赤矢印が"Blip"が起きる瞬間です

解決策

x-cloakを使うべし

これを使えば”Blip”の間も非表示にすることができます。

まずCSSにx-cloakを追加して、

style.css
[x-cloak] { display: none !important; }

HTMLにx-cloakを付けて終わりどすえ。

<button x-data={ 
    open: false, 
    toggleOpen(){ open = ! open }
    }>

<div x-cloak x-show="open">やっほー</div>
        ↑ココ

これでBlipを解消できるンゴ

おまけ

x-cloakはx-ifで代用可能

x-cloakを使わずに、x-ifを使って解決することもできるようです。
ただ、x-ifでの代用する方法はどんな場面で使えるかはわかりません。
とりあえずx-cloakを使っときましょ。

↓代用についてもここに書いてます。

3
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?