Vue・Nuxtでslotの中身の有無で処理を分ける方法 【$scopedSlotsを使います】
VueやNuxtで、slotの利用時に、v-slotでslotの処理を複数に分けていて、slotが渡されていれば表示・slotが渡されていなければ非表示にするというような処理を書きたい時に使える便利な方法について解説します。
この記事を書いている僕は、フロントエンドのプログラマー(フリーランス)として、これまで4年ほどのWeb制作経験があり、Vue,React,Nuxtなどフロントエンドの開発を得意としています。
この記事を読むことによって、Vueのslotで中身の有無により処理を切り分けることができるようになります。
Vue・Nuxtでslotの中身の有無で処理を分ける方法 【$scopedSlotsを使う】
結論としては、公式にもある$scopedSlotsを使うことによって、v-ifによる処理の切り分けができるようになります。
ちなみにVueのslotの基本的な使い方を知りたい方は「【Vue】slotの使い方 【名前付きスロット・スロットプロパティ・省略記法】」の記事をご覧ください。
具体的な例を挙げていきます。
▼親コンポーネント
<template>
<div class="block">
<ExampleChild>
<template v-slot:title>
<span>Example: slotの有無で表示を切り分ける方法</span>
</template>
<template v-slot:description>
<p>こんにちは、山田さん</p>
</template>
</ExampleChild>
</div>
</template>
▼子コンポーネント (修正前:通常)
<template>
<div class="block">
<h1>
<slot name="title"></slot>
</h1>
<div class="container">
<slot name="description"></slot>
</div>
</div>
</template>
上記のようなコードがあった場合、name="title"
とname="description"
のコンテンツの両方があれば問題ないのですが、例えばname="title"
がslot
で渡されない場合は、空のh1
タグが残ってしまいます。こういう時に「this.$scopedSlotstitle
」「this.$scopedSlots.description
」など「$scopedSlots
」によって判定することが可能になります。
▼子コンポーネントの修正の例 (修正後)
<template>
<div class="block">
<h1 v-if="this.$scopedSlots.title">
<slot name="title"></slot>
</h1>
<div
v-if="this.$scopedSlots.description"
class="container"
>
<slot name="description"></slot>
</div>
</div>
</template>
このように「this.$scopedSlots
」を利用することで、slot
の有無によりv-if
のブロックごと非表示にすることが可能です。
また複数ではなく単一のslot
タグを使っている際に判定したい際は「this.$scopedSlots.default
」を使った判定をすれば同じことができるようになります。
ちなみにVueバージョン2.6.0以降では、$slots
は$scopedSlots
にも関数として公開されるようになり、常に $scopedSlots
経由でスロットにアクセスすることが推奨されるようになりました。$slots
ではなく、$scopedSlots
を使うようにしましょう。
オススメするVueの参考動画
参考までに有益な動画をご紹介します。この動画のSlotのセクションでは本記事の内容を基礎〜より深堀りして解説していたりもしてVueの知識が深まると思います。
» 超Vue.js 2 完全パック (Vue Router, Vuex含む)
動画サイトのUdemyだと金額も本と同等かそれ以上にコスパが良いです。僕も購入して勉強したところ大変有益だったので、有料ですが高くないのでよければ参考にしてみてください。
ご参考になれば幸いです。
※当サイトでは一部のリンクについてアフィリエイトプログラムを利用して商品を紹介しています