[ JavaScript] 一ヶ月後(nヵ月後)を取得する関数

タイトルのものが欲しくて探したら以下のページにズバリの回答が複数あったのですが、出来れば「2017/2/1」だと「2017/2/28」のように月末を取得して、「2017/2/13」だと「2017/3/12」のように3/13ではなく前日を取れるようにしたかったので変更を少し加えてみました。

参考サイト: Javascript function to add X months to a date

[javascript]
Date.prototype.addMonth = function( m ) {
var d = new Date( this );
var dates = d.getDate();
var years = Math.floor( m / 12 );
var months = m – ( years * 12 );
if( years ) d.setFullYear( d.getFullYear() + years );
if( months ) d.setMonth( d.getMonth() + months );
if( dates == 1 ) {
d.setDate( 0 );
} else {
d.setDate( d.getDate() – 1 );
}
return d;
}
[/javascript]

使い方はこんな感じです。

[javascript]
var d = new Date( ‘2017-04-20’ );
var m = d.addMonth( 1 );
console.log( m );
// Fri May 19 2017 09:00:00 GMT+0900

var d = new Date( ‘2017-04-01’ );
var m = d.addMonth( 1 );
console.log( m );
// Sun Apr 30 2017 09:00:00 GMT+0900
[/javascript]

記事の中にある画像データをサムネイルで取得する関数

記事の中にある画像を直接取得する方法です。

get_children関数やthe_post_thumbnail関数が利用できない場面で使えると思います。
似たような関数を探せば同じようなものが出てくるのですが、どうも画像のURL属性しか取得していない感じですので「ちょっと違うなー」と思って作ってみました。

この関数の良いところは「attachment_id」が取得できる事です。
つまりidさえ取得できれば「wp-get_attachment_****」と付くものは使えるという事です。

[php]
/*
記事の中から指定された順番の画像データを取得
(imgタグのclass属性 wp-image-XX を利用)
$content : $post->post_content
$idx : 記事内の画像の表示順
*/
function get_post_image($content="", $idx=0) {
$thumb = "";
if(strlen($content) === 0) return $thumb;

// imgタグのwp-image-ID クラスを検索
preg_match_all(‘/wp-image-(\d+)/’, $content, $m);

if(count($m[1]) > 0) {
while(!isset($m[1][$idx])) {
$idx–;
if($idx < 0) break;
}
// $m[1][$idx] = attachment_id
if($idx > -1) $thumb = wp_get_attachment_image($m[1][$idx]);
}

return $thumb;
}

[/php]

functions.phpなんかに書いておけば良いかと思います。

呼び出すときは、

[php]
if(has_post_thumbnail()) :
$thumb = get_the_post_thumbnail();
else:
$thumb = get_post_image(get_the_content());
endif;
[/php]

でサムネイル画像が取得できます。

返り値

<img>タグ。取得できなかった場合は空文字です。

<img>タグは20行目のwp_get_attachment_imageで取得しているので、ここを色々変更すれば自由に加工できます。

オプション値について

$content
HTMLの記事です
$idx
記事に表示される画像の○番目を取得します。(※1番目の画像 = 0)
○番目の画像が見つからない場合は$idxを除算しながら取得します。

注意!!

この関数はwordpressがimgタグに自動で付加する「wp-image-XX」というclassから取得しています。
今後、wordpressの仕様が変更になると利用できなくなる可能性があるのでご注意ください。