WordPressのカスタマイズ方法やプラグインレビューを中心に、パソコン/動物/植物のことなどを紹介するホームページです

WordPressで画像を使ったメニューを作成する方法いろいろ

公開日:2018(平成30)年6月23日/最終更新日:

Knowledge Base Wordpress 設定



【景品表示法に基づく表記】ページ内のコンテンツには、商品プロモーションが含まれています

画像を使ったメニュー??と言われてもピンとこないかも知れません。何より例を見てもらうのが一番ということで、例えば某テレビ局のサイトにある

WordPressで画像を使ったメニューを作成する方法いろいろ|Knowledge Base

のようなメニュー表現(赤枠の部分)。企業サイトなどでは結構使われていますよね?

WordPressでは過去記事へのリンクをタイル状に表示する有名なものに

などがありますが、あくまでもこれは過去記事を抽出したものをアイキャッチ画像と共にきれいに表示する機能。

今回はそうではなく、特定の固定ページなどへのリンクを画像を使って作ってしまおう!というのがテーマです。

この画像メニューを作る方法(というかアイディア)は想像力を広げるといろいろなものを使って実装できるのですが、私の思いつくまま、いくつか紹介させていただきたいと思います。

・・・の前に、リンク付きの画像??という方に基本的なHTML記述方法を紹介します(基本的なものです)

<a href="リンク先のURL"><img src="画像のURL" alt="画像が表示できない場合の文字列" width="画像の幅" height="画像の高さ" /></a>

この中の「リンク先のURL」「画像のURL」「画像が表示できない場合の文字列」「画像の幅」「画像の高さ」を設定すればOKです。

WordPressの場合は投稿編集画面からメディアの追加で簡単に画像リンクが作成できるので、このタグを覚えなくても大丈夫です

単純に用意した画像を並べて画像メニューを作成する方法

画像リンクのタグでは画像の幅や高さは調整できるものの、よりきれいに確実に表示するためには同じサイズの画像を用意した方がいいと思います。一番単純で簡単な方法です。

テーブル要素を使う

テーブルタグ(table)は表の作成によく使われるタグですが、画像などを並べて表示する際にも重宝します。

基本的なコード体系は3列表示なら

<table width="95%">
<tr>
<td width="33%">画像タグ1</td>
<td width="33%">画像タグ2</td>
<td width="33%">画像タグ3</td>
</tr>

<tr>
<td width="33%">画像タグ4</td>
<td width="33%">画像タグ5</td>
<td width="33%">画像タグ6</td>
</tr>
</table>

というように、tableタグで上下を囲み、trタグが1行分、その中にtdタグで列を作ることで表での表示になります。

更に↑の例のように本文の幅の95%でテーブルを表示しなさいそれぞれの列は33%ずつで表示しなさいとすることでサイト本文の幅からはみ出すことなく3等分された形で表示できます。

ちなみに4等分したかったら各tdを25%にしてtdの数を4つにすればいいということになりますね。

画像のサイズは3列表示なら3等分した1つの幅と同じか少し大きな画像にしておけばよりきれいに表示できます。

レスポンシブ対応させて表示する

前項のテーブルを使った方法で問題となるのは、パソコンなどの大きな画面ではきれいに表示できても画面の狭いスマホ表示の際には狭い画像がさらに3等分されてしまい、画像が小さくなってしまうこと。スマホからのアクセスが多いサイトではちょっと不便ですね。

これを解消するにはテーブルでの使用をやめdivとCSSで自動調整させる方法が一般的です。

やり方は簡単、画像タグを用意したものを列記してそれをまとまりですよ!とdivタグで囲みます

<div class="〇〇">
画像リンク1
画像リンク2
画像リンク3
</div>

こう記述すると画像が縦に並んでしまいますから、テーマのCSSに以下を追記します

.〇〇{float:left;}

すると・・・画像から左から右へ、本文の幅の分だけ表示されるようになります。

こうしておくとスマホ表示でも画像が右へ表示できないものは勝手に改行されて下に下に表示されるので見やすくなると思います。

ただ1つ気を付けるべきは画像の大きさ。スマホ表示でも1列になり、かつ、デスクトップ表示でもいい感じの列数になる値を調整する必要があります。パソコン表示の場合にはテーマの本文の幅、スマホ表示の場合には画面の幅に合わせる必要があるのである程度のところで折衷することになると思います。

マウスオーバー(ホーバー)時に特殊効果を与えてメニューを表示する方法

これがプラグインの特徴を知ってるかどうか?が問われるところになります。アレを使えば簡単じゃん!と思われた方はいろいろなプラグインを使ったことのある方だと思います。

何を使うか・・・それは画像ホーバー時に特殊効果を与える画像アルバム系のプラグインです。

マウスオーバー時にどう動作させたいか??というところでいろいろなプラグインの中からの選択が難しいところですが、

  1. レスポンシブ表示できる
  2. 列数の指定ができる
  3. マウスオーバー時にキャプション(画像の説明)が表示できる
  4. クリックしてどこかのページへ移動する

という要件ではImage Hover Effects CSS3というプラグインがおすすめです

※プラグインの紹介記事は作成中です。公開したらリンクを張る予定ですのでそれまでは上のリンクから公式ページをご覧ください

マウスオーバー時に音を鳴らすメニューを作る方法

というプラグインを使います。このプラグインは画像や段落などのタグに指定したidに応じて設定した音声をマウスオーバー時に流すものです。古いプラグインですが現行バージョン(4.9.6)でも動作しました。この機能を持つプラグインとしては唯一だと思われます。

これを使用して音声を流すには、前述したようにタグにidを設ける必要があります。id要素はテーブル・列・行・画像・段落などいろいろなタグに「id=〇〇」と付け加えるだけなので、前述したテーブル表示などでもtdやimgのタグ内で使えます。

※ご存知かと思いますが、id要素は同一ページ内に混在させることができませんので、今回の仕組みの場合には1画像につき1つのidを割り振る必要があります

※プラグインについての詳しい説明はリンク先ページをご覧ください。

マウスオーバー時に文字を表示する特殊効果を与え、さらに音を出すメニューを作る方法

これ究極の方法かもしれません。結構この機能をWordPressで実装するのに苦労しました。

前述した方法としてマウスオーバーしたときにリンク先の内容を説明するような音を出すというのを紹介しましたので、別にキャプションを表示しなくても内容は分かる!!と制作者は思いがちですが、音が出ないように設定されている環境ではどうなの?というところも考える必要があります。

それならマウスオーバーしたときにキャプションを表示する方法を用いつつ、音も出るようにすればより親切ではないか?という複合的な使い方を紹介します。

ちょっと複雑なので見様見真似でやってみてくださいね。

まずは画像のマウスオーバー時にエフェクト(効果)を与えます。そしてそこに音声を流すようにします。

音声を流す方法は前述した「マウスオーバー時に音を鳴らすメニューを作る方法」を参照ください。

そして画像にエフェクトを加える方法ですが、前述したImage Hover Effects CSS3は残念ながらid要素を加えることができませんので、音声も再生されなくなってしまいますので、別のプラグインを使います。

探せば他にもあると思われますが、今回は「Image Caption Hover」というプラグインを使用します。このプラグインは機能としてはImage Hover Effects CSS3よりもエフェクトの種類が少ないものの、機能としては十分だと思います。

で実装方法ですが・・・

Image Caption Hoverでは1つの画像ギャラリーに対して1つのidが付与されます(画像ごとではないです)。したがって、メニュー分だけ画像1枚だけのギャラリーを作成します。

そしてtable要素の中にギャラリーのショートコードを挿入すると、id付きで、かつホーバーエフェクト付きの画像が表示されるようになります。

そこに「マウスオーバー時に音を鳴らすメニューを作る方法」で紹介した方法を加えると・・・画像にマウスオーバーしたときにはImage Caption Hoverでキャプション情報が表示され、かつ、Hover Soundで音声が流れるという仕組みが完成します。


いかがでしたか?以上が今回のテーマ「WordPressで画像を使ったメニューを作成する方法いろいろ」のすべてです。工夫すればもっと簡単にもっと便利にという方法があるかも知れませんが、固定ページなどに画像を使ったメニューを作りたい!!と思っている方の参考になれば幸いです。

著:清水 由規, 著:清水 久美子, 著:鈴木 力哉, 著:西岡 由美, 読み手:星野 邦敏, 読み手:吉田 裕介
¥2,889 (2024/02/08 17:07時点 | Amazon調べ)