この記事は最後に更新してから1年以上経過しています。

canvasタグを投稿したい

説明

以前「投稿内容のid属性などを保存するための対策」で取り上げたように、WordPressでは投稿に記述できるHTMLタグが制限されている。同コラムでこの制限を調整する対策を紹介しているが、3.5以降ではフィルター関数を登録して対応できるようだ。

投稿情報に有効なHTMLタグをまとめた $allowedposttagsは、globalキーワードを使用することで自テーマのfunctions.phpで参照・更新でき、3.4の時点ではadmin_initアクション関数を登録してその中で更新して対応していた。この方法は現在でも意図通り動作しているのだが、3.5で登場した wp_kses_allowed_html関数が登場し、この中で呼び出される'wp_kses_allowed_html'フィルター関数で対応するのが、よりスマートだと思われる。

自テーマのfunctions.phpに記述する内容は次の通り。

add_filter( 'wp_kses_allowed_html', 'mytheme_wp_kses_allowed_html', 10, 2 );

function web_tool_wp_kses_allowed_html( $tags, $context ) {
	if ( $context == 'post' ) {
		$tags['div']['id'] = true;
		$tags['canvas'] = array( 'id'=>true, 'width'=>true, 'height'=>true );
	}
	return $tags;
}

上記の例では、パラメータ$contextが'post'の場合のみcanvasタグのほかにdivタグのid属性を有効にしている。自サイトの投稿で使用したいHTMLタグやその属性を適時指定してほしい。

標準で使用できるHTMLタグは、/wp-includes/kses.phpを参照で$allowedposttagsの定義箇所を参照。なお一部のプラグインでも$allowedposttagsの内容を操作しているようなので、その点も意識しておきたい。


最終更新 : 2013年12月27日 16:30


お勧め

wp_normalize_path(2018年7月6日 更新)

string wp_normalize_path( string $path )
パス名を標準化する。

is_search(2018年5月27日 更新)

bool is_search( )
要求されているページが、検索結果ページか調べる。

wp_parse_args(2012年7月19日 更新)

array wp_parse_args( mixed $args, mixed $defaults = '' )
クエリー文字列を解析し、各パラメータのデフォルト値とマージした連想配列を取得する。

the_post_thumbnail(2018年5月27日 更新)

void the_post_thumbnail( [ mixed $size = 'post-thumbnail' [ , mixed $attr = '' ] ] )
アイキャッチ画像(サムネイル)を表示する。

wp_add_inline_script(2018年5月27日 更新)

bool wp_add_inline_script( string $handle, string $data [ , string $position = 'after' ] )
インラインスクリプトを追加する。