我使用wp_editor创建了一个前端编辑器,它可以正常运行。
经过测试,我注意到它正在删除已插入内容的任何短代码。我已经调查了这个问题,发现它是' ob _' (输出缓冲)正在删除它们。如果我删除此输出缓冲,则短代码显示正常,但它会破坏我为编辑器创建的功能。
我如何保留下面使用的代码,但修改它以确保显示所有短代码?任何帮助/想法非常感谢,S。
if(!is_feed() && current_user_can( 'manage_network' ) ) :
function ps_add_post_editor($content) {
global $post;
$settings = array(
'wpautop' => true,
'media_buttons' => false
);
$content .= '<div id="content-edit-area" style="display:none;"><form action="" id="page-content-editor-panel" method="post"><span id="ajax_my_post_edit_nonce" class="hidden">' . wp_create_nonce( 'ajax_my_post_edit_nonce' ) . '</span>' . ps_get_wp_editor($post->post_content, 'textarea-' . $post->ID , $settings) . '<input type="submit" id="feesavebtn" value="Save" /></form><a href="#" id="cancelbtn">Cancel</a></div><br><br><div id="loadingmessage"><img src="'.get_template_directory_uri().'/images/loading.gif" /> saving...</div>
<style type="text/css">
#textarea-'.$post->ID.'_ifr, #textarea-'.$post->ID.' { min-height:700px !important; }
</style>
<script type="text/javascript">
jQuery(\'#page-content-editor-panel\').submit(function(){
var pageid = '.$post->ID.';
var content;
var editor = tinyMCE.get(\'textarea-'.$post->ID.'\');
if (editor) {
content = editor.getContent();
} else {
content = jQuery(\'#textarea-'.$post->ID.'\').val();
}
jQuery(\'#content-edit-area\').hide();
jQuery(\'#loadingmessage\').show();
jQuery.post(
ajaxurl,
{
\'action\':\'add_foobar\',
\'nonce\':jQuery(\'#ajax_my_post_edit_nonce\').text(),
\'post_id\':pageid,
\'post_data\':content
},
function(response){
window.location.reload(true);
}
);
return false;
});
</script>';
return $content;
}
function ps_get_wp_editor($content,$textarea,$settings) {
ob_start();
wp_editor($content, $textarea, $settings);
$edior_html_code = ob_get_contents();
ob_end_clean();
return $edior_html_code;
}
add_filter('the_content', 'ps_add_post_editor');
add_action('wp_ajax_add_foobar', 'prefix_ajax_add_foobar');
add_action('wp_ajax_nopriv_add_foobar', 'prefix_ajax_add_foobar');
function prefix_ajax_add_foobar() {
if( wp_verify_nonce( $_REQUEST['nonce'], 'ajax_my_post_edit_nonce' ) ) {
$myfee_post = array();
$myfee_post['ID'] = $_POST['post_id'];
$myfee_post['post_content'] = $_POST['post_data'];
wp_update_post( $myfee_post );
die("This page has now been updated.");
} else {
die("Unable to process your request at this time.");
}
}
endif;
答案 0 :(得分:1)
我必须承认,我不完全确定你的目标是什么,但是对于它的价值,这似乎对我有用:
remove_filter('the_content', 'do_shortcode', 11);
function ps_get_wp_editor($content,$textarea,$settings = array()) {
ob_start();
wp_editor($content, $textarea, $settings);
$editor_html_code = ob_get_contents();
ob_end_clean();
return $editor_html_code;
}
function ps_add_post_editor($content) {
global $post;
$post_content = $post->post_content;
$content = ps_get_wp_editor($post_content, 'ps-editor-' . $post->ID );
return $content;
}
add_filter('the_content', 'ps_add_post_editor');
function ps_eat_pants() {
return "eat pants has happened";
}
add_shortcode('eat_pants', 'ps_eat_pants');
问题是,如果您希望能够编辑后端编辑器中的短代码,则需要从'the_content'中删除'do_shortcode'过滤器,以便在显示时不会运行在前端。
我不得不承认,我不知道你发布的代码是如何工作的,我假设它是错误的或缺乏上下文。 =)
我的意思是,你实际上没有给你的功能提供所有必要的参数......
如果您更详细地解释了您正在做的事情,这可能有所帮助,但我希望这会有所帮助。
[编辑:哦,那个“eat_pants”的东西只是一个测试短代码...]