Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Trying to access array offset on int in /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php on line 242

Warning: Cannot modify header information - headers already sent by (output started at /home/igial/presentnote.com/public_html/wp-content/plugins/secure-wordpress/res/inc/SwpaPlugin.php:242) in /home/igial/presentnote.com/public_html/wp-includes/feed-rss2.php on line 8
Twenty Twelve – PresentNote https://presentnote.com Just another WordPress site Thu, 09 May 2019 02:04:40 +0000 ja hourly 1 https://wordpress.org/?v=6.3.8 https://presentnote.com/wp-content/uploads/2019/05/favicon-pn.ico Twenty Twelve – PresentNote https://presentnote.com 32 32 ヘッダー・フッター・ナビメニューなどを横幅いっぱいに広げるCSSの書き方-Twenty Twelve篇- https://presentnote.com/widen-header-footer-menu-css-2012/ https://presentnote.com/widen-header-footer-menu-css-2012/#comments Thu, 27 Jun 2013 09:40:41 +0000 http://presentnote.com/?p=2761 よく他のウェブサイトをデザインの参考に見ていると、ヘッダーの背景やフッターの背景、またグローバルナビゲーションメニューなどが横いっぱいに広がっているデザインを見かけます。サイトコンテンツは中央に配置されているのに、背景だけ横いっぱい、ブラウザいっぱいに広がっているのです。
以前、Twenty Eleven でこのようなデザインに変更するための方法を記事にしました。今回は Twenty Twelve で同じようにできないかやってみましたので、その方法をお伝えしたいと思います。
基本的な考え方は Twenty Eleven の場合と同じですが、Twenty Twelve の場合、元の CSS に書かれているある記述のせいでつまずいてしまいました。そのつまずき部分を解消し、ヘッダーやフッターなどの背景をブラウザの画面いっぱいに広げ、ダイナミックなレイアウト・デザインへと変更する方法をお伝えしたいと思います。

スタイルシート(子テーマ)への記述内容

全てに共通する記述

html {
 overflow: auto;
}
body {
 overflow: hidden;
}
@media screen and (min-width: 600px) {
 .site {
  overflow: visible;
 }
}

横幅を広げたい部分に関する記述

#example {
 margin-right: -500%;
 margin-left: -500%;
 padding-right: 500%;
 padding-left: 500%;
}

Twenty Twelveの基本となるパーツのセレクタはこちら

ヘッダー #masthead
グローバルメニュー #site-navigation
.main-navigation
※注
フッター #colophon

注)グローバルメニューのセレクタについて

グローバルメニューのデザインを指定しているセレクタは、上記の id や class 以外にもいくつもあります。メニューをどのようにカスタマイズしているかで、指定すべきセレクタが変わってくるようです。
特に Twenty Twelve のグローバルナビメニューは、上下に 1px のボーダーが引かれていますが、実は上記の 2 つのセレクタでは、このボーダーまで横に伸ばすことができません。
ボーダーも横に伸ばしたい場合は、以下のセレクタを、左右のマージン、パディングともに引き延ばす必要があります。

デフォルト状態のグローバルナビメニュー

デフォルト状態のグローバルナビは、作成した固定ページへのリンクが順番に表示されるようになっています。1460 行目からの記述にマージンやパディングを追記すると、ボーダーも含めて横幅を広げることが可能です。

/* Minimum width of 600 pixels. */
@media screen and (min-width: 600px) {
/* 〜省略〜 */
 .main-navigation ul.nav-menu,
 .main-navigation div.nav-menu > ul {
  border-bottom: 1px solid #ededed;
  border-top: 1px solid #ededed;
  display: inline-block !important;
  text-align: left;
  width: 100%;
  margin-right: -500%;
  margin-left: -500%;
  padding-right: 500%;
  padding-left: 500%;
 }
}

カスタムメニューで変更した場合のグローバルナビメニュー

カスタムメニューで独自のメニューを作成し、グローバルナビに適用させた場合は、上記のセレクタ以外にも以下のセレクタが使えます。

#menu-global-nav {
 margin-right: -500%;
 margin-left: -500%;
 padding-right: 500%;
 padding-left: 500%;
}
2013.06.29 追記
Twenty Twelve を使っているサイトを複数確認したところ、別のサイトでは #menu-global-nav が使われていませんでした。代わりに、【 #menu-main 】と表示されていました。どんなセレクタが指定されているかは、Firebug( Firefox のプラグイン)などを使ってサイトごとに確認した方がいいみたいです。

Twenty Twelveでの注意点とは?

Twenty Eleven の記事でもお伝えしたように、基本的な考え方は変わりません。なので、別に Twenty Eleven でなくても Twenty Twelve でなくても使えるテクニックです。
ただ、Twenty Twelve の場合はデフォルトの CSS で影響で、うまくいかず、ちょっとした工夫が必要になります。
以下は上記設定の考え方になりますので、興味のある方はどうぞ・・・。

グローバルナビゲーションメニューだけ広がらない

Twenty Eleven の場合と同じようにスタイルシートを記述した場合、グローバルメニューの部分がブラウザいっぱいに広がってくれません。以下のようにある範囲までしか広がらないのです。
ブラウザ全体に広がらないよ横幅
その範囲はというと、どうやら【 .site 】というセレクタで指定されている部分のようです。

なぜ、グロナビはサイトの範囲内までしか横に広がってくれないのか?

その原因はスタイルシートに記述されている【 overflow 】の値にありました。デフォルトでは以下のように記述されています。

/* =Media queries
-------------------------------------------------------------- */
/* Minimum width of 600 pixels. */
@media screen and (min-width: 600px) {
/* 〜省略〜 */
 .site {
  margin: 0 auto;
  max-width: 960px;
  max-width: 68.571428571rem;
  overflow: hidden;
 }

この【 overflow 】ははみ出た部分をどうするか、ということを指定しています。デフォルトの指定は【 hidden 】なので、はみ出た部分は非表示になります。つまりこれが原因で横に広がった部分が表示されず、サイトの範囲内に収まったように見えていたわけです。
この部分を表示させるには、【 overflow 】の値を【 hidden 】から【 visible 】へ変更する必要があります。これで、グローバルナビゲーションメニューも左右横にちゃんと広がってくれます。

]]>
https://presentnote.com/widen-header-footer-menu-css-2012/feed/ 1
WordPressの投稿記事一覧を抜粋表示する条件分岐タグの使い方-メイン・カテゴリー・タグ・アーカイブページなど- https://presentnote.com/how-to-use-conditional-tags-to-excerpt/ https://presentnote.com/how-to-use-conditional-tags-to-excerpt/#respond Fri, 21 Dec 2012 22:46:22 +0000 http://presentnote.com/?p=1980 WordPress で投稿した記事の表示方法には 2 通りあります。1 つは全文表示。もう 1 つは抜粋表示です。
使い分けとしては、、、

  • トップページやアーカイブページなどでは抜粋表示
  • 記事全文を読みたい場合の個別投稿ページでは全文表示

というのがベターだと思います。
しかし、WordPress のデフォルトテンプレートである Twenty Eleven や Twenty Twelve など、初期設定のままだとトップページやアーカイブページでも全文表示なっているます。いちいち タグを挿し込むのも面倒くさい・・・。他のテンプレートでも同じようになっているかもしれません。
この記事では、条件分岐タグを使って全文表示と抜粋表示を使い分ける方法をご紹介します。

条件分岐タグの役割を理解しよう

まず、簡単にWordPressの条件分岐タグについて説明しておきたいと思います。理屈はそんなに難しくないはずです。PHPを使っていますが、特に専門的な知識がなくても使えてしまう便利さがあります。(少なくともぼくはPHP、よく分っていません)
条件分岐タグの基本構造は・・・

もし【条件1】なら【表示1】、それ以外は【表示2】でお願いね

というものです。簡単ですよね?これを実際のPHPのタグに合わせて見てみましょう。

<?php if ( 【条件1】 ) : ?>
【表示1】
<?php else : ?>
【表示2】
<?php endif; ?>
もし <?php if ( 【条件1】 ) : ?>
【表示1】 任意のタグ
それ以外は <?php else : ?>
【表示2】 任意のタグ
条件指定終わり <?php endif; ?>

といった感じです。あとは、これらを踏まえて指定したい条件と表示させたい内容のタグを埋め込んでいけばいいというわけです。

条件を複数指定したい場合

条件を複数指定したい場合は、【 || 】この縦2本のラインを挟めばOKです。例えば、「もし、【条件1】【条件2】【条件3】の場合は・・・」というような指定をしたい場合は以下のように指定します。

<?php if ( 【条件1】 || 【条件2】 || 【条件3】 ) : ?>

多分、抜粋表示をさせたいのはカテゴリーページやタグページなど、複数に渡るはずなので、この複数の条件指定を覚えておきましょう。
ちなみに、この線( → | )なんて呼ぶのか分りませんが、キーボードの右上にあるはずです。。。

条件分岐タグを使って全文表示と抜粋表示を切り替える

さて、いよいよ実践です。今回は以下のように指定したいと思います。

抜粋表示 トップページ(投稿一覧)
アーカイブページ(archive.php)
検索結果一覧ページ(search.php)
全文表示 個別投稿ページ(single.php)
固定ページ(page.php)など

つまり、文章にしてみると、『もし、トップページ・アーカイブページ・検索結果エページの場合は抜粋表示にして、それ以外の場合は全文表示にしてね』となります。
ちなみに、アーカイブページとは、「カテゴリーページ」・「タグページ」・「作成別ページ」・「日付別ページ」の結果を全て含んでいます。なので、条件としてはアーカイブページを指定しておけばOKです。

全文と抜粋を着替える条件分岐タグの指定例

全文表示と抜粋表示の切り替えを指定するためには以下のように記述します。

<?php if ( is_home() || is_archive() || is_search() ) : ?>
	<?php the_excerpt(); ?>
<?php else : ?>
	<?php the_content(); ?>
<?php endif; ?>

ちなみに、トップページを指定する WordPress の条件分岐タグは

is_home()

カテゴリーページを指定する条件分岐タグは

is_archive()

検索結果一覧ページを指定する条件分岐タグは

is_search()

です。
また、抜粋表示を示す WordPress のタグは

<?php the_excerpt(); ?>

全文表示を示すタグは

<?php the_content(); ?>

です。実際はスタイルシートの指定やその他の PHP が記述されていると思いますが、単純化するとこのようになっています。

タグはどこに書き込めばいいのか?

ここからは Twenty Eleven、もしくは Twenty Twelve を元に解説していきます。条件指定の仕方は WordPress 共通していますので、お使いのテンプレートに合わせてカスタマイズしてみてください。
それでは、まずは content.php を開きましょう。Twenty Eleven は 35 行目、Twenty Twelve は 33 行目辺りから、コンテンツの表示方法についての記述があります(子テーマに複製してから作業してくださいね)。

<?php if ( is_search() ) : // Only display Excerpts for Search ?>
<div class="entry-summary">
	<?php the_excerpt(); ?>
</div><!-- .entry-summary -->
<?php else : ?>
<div class="entry-content">
	<?php the_content( __( 'Continue reading <span class="meta-nav">&rarr;</span>', 'twentyeleven' ) ); ?>
	<?php wp_link_pages( array( 'before' => '<div class="page-link"><span>' . __( 'Pages:', 'twentyeleven' ) . '</span>', 'after' => '</div>' ) ); ?>
</div><!-- .entry-content -->
<?php endif; ?>

元々の記述内容は、『もし、検索結果一覧ページなら抜粋表示にして、それ以外は全文表示にしてね〜』となっています。なので、単純に最初の

<?php if ( is_search() ) : // Only display Excerpts for Search ?>

の部分を

<?php if ( is_search() || is_home() || is_archive() ) : // Only display Excerpts for Search ?>

に変更すれば OK です。
簡単ですね。ぜひ試してみてください。

]]>
https://presentnote.com/how-to-use-conditional-tags-to-excerpt/feed/ 0
WordPressテーマTwenty Twelveの投稿ページを抜粋表示にする方法 https://presentnote.com/how-to-excerpt-posts-wordpress-twentytwelve/ https://presentnote.com/how-to-excerpt-posts-wordpress-twentytwelve/#respond Sat, 15 Dec 2012 06:09:31 +0000 http://presentnote.com/?p=1921 2012/12/22 追記
もっと簡単に設定する方法が分りました。
詳しくはこちらの記事をご覧ください。
WordPress の投稿記事一覧を抜粋表示する条件分岐タグの使い方

WordPress がバージョンアップして 3.5 になりました。それに伴って、新テンプレートの Twenty Twelve も登場。だいぶシンプルで無駄のないデザインになっています。ミニマルデザイン好きなので個人的には好きです。カスタマイズの方もおもしろくなりそうです。
Twenty Twelve も、以前 Twenty Eleven 同様、ブログの最新の投稿が一覧で表示されているページは各投稿が全文表示されてしまいます。厳密に言うと検索結果などの場合は抜粋表示されるようになっていますが、トップページの最新投稿では全文表示の記事が数記事ならぶとスクロールが非常に面倒になってしまいます。
トップページに最新記事一覧を表示させる際には抜粋表示されていた方がいいと思うので、カスタマイズ方法をメモしておきたいと思います。

結論:最新投稿記事を一覧表示するには条件分岐タグを使う

条件分岐タグを使うとうまくいきました。
条件分岐タグとは、WordPress のタグのひとつで、「○○の場合は■■を表示して」のような指示を出すためのタグです。これを使う事によってトップページ(フロントページ)に記事全文が一覧表示されることはなくなり、抜粋表示ができるようになります。

変更するテンプレートと、タグの記述方法

変更を加えるテンプレートは【content.php】です。子テーマにコピーしてから編集してくださいね。
3 行目に以下のような記述があります。

<?php if ( is_search() ) : // Only display Excerpts for Search ?>
<div class="entry-summary">
<?php the_excerpt(); ?>
</div><!-- .entry-summary -->

これは、「もし検索結果なら・・・」という条件を示して、「その場合は【excerpt】、つまり抜粋で表示してね」という指示をしています。この条件を仮に【条件1】としておきます。
そして、その下に以下のようなタグを追記すると・・・

<?php elseif ( is_home() ) : ?>
<div class="entry-summary">
<?php the_excerpt(); ?>
</div><!-- .entry-summary -->

「もし、【条件1】でない場合は、こっちの条件を適用してね」という指示を出すことができます。同じように抜粋にするタグを埋め込んでいるので、「もし、条件1でない場合は、抜粋で表示してね」という意味になります。一応こちらの条件は【条件2】としておきましょう。

条件分岐タグ【is_home】の意味

ここで指定している条件は、表示設定におけるフロントページの表示で【最新の投稿】を指定している場合のトップページや、【固定ページ】を指定している場合の投稿ページに反映されます。

各個別投稿記事を見る場合は全文表示に

これでトップページで投稿記事が一覧表示されている場合に抜粋記事として表示させることができます。そして、記事タイトルをクリックすると全文表示の個別投稿記事のページが表示されるようになります。
その条件を指定しているのは、先ほど【条件2】のタグを追記した後に書かれている【else】から始まる部分です。意味としては、「【条件1】でも【条件2】でもない場合は〜」ということで、この場合は全文表示などを指示しています。

参考にさせて頂いたブログ

ありがとうございます!

]]>
https://presentnote.com/how-to-excerpt-posts-wordpress-twentytwelve/feed/ 0