画像マウスオーバーでキャプションを表示

メディアをアップロードした際に、「キャプション」項目にテキストを設定された画像を挿入した場合はキャプションショートコードが生成され、ページ内の各画像下にその設定したテキストが表示されます。
今回、キャプションをあらかじめ非表示にしておいてマウスオーバーすると表示されるような実装をしてみました。プラグインを探してみたのですがいい感じのものが見つけれなかった。(ご存知であれば、ご教授いただければと)
まずはキャプションの表示のされ方
ショートコードは以下のようなフォーマットになります。
[caption id="attachment_25" align="alignnone" width="300"] <a href="画像URL"> <img src="画像URL" alt="キャプション" width="画像幅" height="画像高" class="size-medium wp-image-[id]" /> </a> キャプション [/caption]
このショートコードからデフォルトでは以下のように出力されます。
<div id="attachment_[id]" style="width: [画像幅+10px]" class="wp-caption alignnone"> <a href="画像URL" data-slb-group="66" data-slb-active="1" data-slb-internal="0"> <img src="画像URL" alt="キャプション" width="画像幅" height="画像高" class="size-medium wp-image-[id]" /> </a> <p class="wp-caption-text">キャプション</p> </div>
3.9からはHTML5対応され、以下のように出力することも可能になりました。
<figure id="attachment_[id]" style="width: [画像幅];" class="wp-caption alignnone"> <a href="画像URL" data-slb-group="66" data-slb-active="1" data-slb-internal="0"> <img src="画像URL" alt="キャプション" width="画像幅" height="画像高" class="size-medium wp-image-[id]" /> </a> <figcaption class="wp-caption-text">キャプション</figcaption> </figure>
figureタグの説明と対応ブラウザのバージョンはこちら HTML <figure> Tag
キャプションショートコードをHTML5対応にする
テーマによっては、(functions.phpなどで)追加してくれているものが増えてきています。
追加する場合は、finctions.phpに以下を追加して下さい。
add_action( 'after_setup_theme', 'my_theme_support'); function my_theme_support(){ add_theme_support( 'html5', array( 'caption', )); }
+10pxの余白を除去
キャプション挿入のショートコードを使用した際に画像の右側に10pxついてしまうのでつけないようにしました。気になるようであれば、以下そのまま子テーマのfunctions.phpに追記してください。
function remove_caption_padding( $width) { return $width - 10; } add_filter( 'img_caption_shortcode_width', 'remove_caption_padding');
本題ですが、2パターン試してみました。
それぞれデモを用意してので試してみて下さい。
1.画像をずらしてキャプションを挿入
画像にマウスオーバーすると全体が上にスライドしてキャプションが見えるようになります。デモ
/* caption.css */ .wp-caption { position: relative; overflow: hidden; } .wp-caption p.wp-caption-text { background-color: #111; color: #EEE; padding: 5px 10px; margin: 0px; }
// caption.js jQuery(document).ready(function($) { $('div.wp-caption').each(function(i) { var img_ = $('img', this); var img_height = img_.attr('height'); var p_height = $('p', this).outerHeight(); $(this).height(img_height); $(this).hover(function() { img_.animate({marginTop : -p_height}, 500); }, function() { img_.animate({marginTop : '0'}, 500); }); }); });
2.画像上にキャプションを挿入
画像にマウスオーバーすると、画像上にキャプションを表示します。デモ
/* caption.css */ .wp-caption { position: relative; overflow: hidden; } .wp-caption p.wp-caption-text { background: none repeat scroll 0 0 #111111; color: #EEE; opacity: 0.8; padding: 5px 10px; margin: 0; }
// caption.js jQuery(document).ready(function($) { $('div.wp-caption').each(function(i) { var p_ = $('p', this); var img_ = $('img', this); var img_height = img_.attr('height'); var p_height = $('p', this).outerHeight(); $(this).height(img_height); $(this).hover(function() { p_.animate({marginTop : -p_height}, 500); }, function() { p_.animate({marginTop : '0'}, 500); }); }); });
実装方法
以下は、caption1.cssとcaption1.jsをそれぞれテーマフォルダ下/cssフォルダ、/jsフォルダに配置したファイルを読み込む例です。functions.phpに追記して下さい。独自のCSSやJSを読み込む
CSSの方は、中身をstyle.cssに追加する方法でもいいです。
function wp_caption_scripts() { wp_enqueue_style( 'caption-slide-css', get_stylesheet_directory_uri() . '/css/caption1.css', false, null ); wp_enqueue_script( 'caption-slide-js', get_stylesheet_directory_uri() . '/js/caption1.js', null, null, true ); } add_action( 'wp_print_scripts', 'wp_caption_scripts');
関連記事
-
-
「最近のコメント」ウィジェットをカスタマイズ
「最近のコメント」ウィジェットは、サイトに投稿されたコメントを新しい日付順に表示してくれます。件数も「ウィジェット」ページで設定できます。(管理画面の「外観」→「ウィジェット」) (削除
-
-
独自のCSSやJSを読み込む
WordPressで、プラグインではなく自作したりダウンロードしてきたCSSやJS(プラグイン)を読み込んだりするケースがあると思います。今回は、その際のCSSやJSファイルの使用方法をまとめてみまし
-
-
Twenty Fourteen クレジットを非表示・変更方法
Twenty Fourteenにも最下部に「Proudly powered by WordPress」というコピーライトが表示されます。それを削除もしくは変更するには、footer.phpを編集して行
-
-
Twenty Ten カスタマイズ
Twenty Tenのカスタマイズについてのまとめです。 目次 コンテンツナビゲーション 非表示 「投稿日」を非表示 「作成者(投稿者)」を非表示 "コメントをどうぞ"("leave a
-
-
Twenty Twelve "Proudly powered by WordPress"をCopyrightに変更
標準でページの最下部に表示される"Proudly ~"を変更します。 子テーマフォルダにfooter.phpをコピーし、以下のように編集を行ってください。リンクを外して、表示部分を書き換えるだけです
-
-
テーブル実装プラグイン「TablePress」 + レスポンシブ対応
「TablePress」は、WordPressにテーブルを実装できるプラグインです。専用のレスポンシブ化のプラグインもリリースされています。ダウンロード デモ (PCの場合はブラウザの幅狭めてみたり
-
-
「カレンダー」ウィジェット カスタマイズ・プラグイン
目次 カレンダー移動をajax遷移させるようにする 営業日・休業日を色分けして表示 ページやウィジェットにgoogleカレンダーを追加 カレンダーウィジェットをajax遷移させるよ
-
-
head内に出力される要素を整理
Wordpressを使用していくうちに、head内がカオスな状態になっていくきますよね。そこで、そういう状態になったものをスッキリさせていこうという試みをやっていこうと思います。 削除方法 取り急
-
-
管理画面のCSSをカスタマイズ
管理画面のスタイルを変更したくなったので、カスタマイズしてみました。一例として以下を取り上げてみます。 「投稿一覧」の画面でカスタムフィールドが追加されていくと、そんなに幅が必要のないところが長くな
-
-
Twenty Twelve サイトタイトルをテキストから画像に置き換え
ページトップに表示されるサイトタイトルをデフォルトのテキストから画像に変更します。 あらかじめ、管理画面のメディアライブラリから画像をアップロードしているもしくは別の場所に保存しているそのファイルの
Comment
WordPress | 画像マウスオーバーでキャプションを表示
メディアをアップロードした際に、「キャプション」項目にテキストを設定された画像を挿入した場合はキャプションショートコードが生成され、ページ内の各画像下にそ... http://t.co/3nzrJDbAqf