有时需要在文章输入一些HTML代码,一般我们会切换到文本编辑模式,但当你切换到可视化模式发表更新文章后,这些 HTML 代码会被WordPress过滤掉而丢失,那么如何防止误操作切换到可视化模式呢,WordPress本身也为我们准备了选项,进入人个资料 → 可视化编辑器,勾选“撰写文章时不使用可视化编辑器 ”。这样编辑文章时仅有文本模式了,编辑其它文章时想使用可视化模式,还要改回来,那如何仅让指定的文章使用文本模式,而不影响其它文章使用可视化模式呢?可以用下面的代码实现。将下面代码添加到当前主题函数模板functions.php中:
// 添加添加面板和保存选项
if ( is_admin() ) {
add_action( 'admin_init', 'zm_edit_in_html_create_options_box' );
add_action( 'admin_head', 'zm_edit_in_html_handler' );
add_action( 'save_post', 'zm_edit_in_html_save_postdata', $post );
}
// 关闭可视化
function zm_edit_in_html_handler() {
global $post;
// 检查这里是否有post对象,否则返回
if( $post == null ) return;
// 获取meta值并检查它是否已打开文本模式
$editInHTML = zm_edit_in_html_get_html_edit_status( $post->ID );
if ( $editInHTML ){
// 隐藏“可视化”选项卡
echo '';
// 将编辑器设置为文本模式
add_filter( 'wp_default_editor', function () {
return 'html';
});
}
}
// 将选项面板添加到所有编辑页面中
function zm_edit_in_html_create_options_box() {
// 添加到页面
add_meta_box( 'zm-edit-in-html', '文本模式', 'zm_edit_in_html_custom_box', 'page', 'side' );
// 添加到文章
add_meta_box( 'zm-edit-in-html', '文本模式', 'zm_edit_in_html_custom_box', 'post', 'side' );
// 添加到所有文章类型
$args = array(
'public' => true,
'_builtin' => false
);
$post_types = get_post_types( $args, 'names' );
foreach ( $post_types as $post_type ) {
add_meta_box( 'zm-edit-in-html', '文本模式', 'zm_edit_in_html_custom_box', $post_type,'side' );
}
}
//创建选项框
function zm_edit_in_html_custom_box( $post ){
// 检查数据是否来自当前文章
wp_nonce_field( basename( __FILE__ ), 'zm_edit_in_html_noncename' );
// 获取当前文章的当前状态
$editInHTML = zm_edit_in_html_get_html_edit_status( $post->ID );
// 功能说明
echo '当前文章始终保持在文本编辑模式';
echo '
