Hallo Leute, ich habe ein TinyMCE zu einigen Textbereichen hinzugefügt, die in einem benutzerdefinierten Meta-Feld angezeigt werden. Alle Formatierungen funktionieren einwandfrei, mit der Ausnahme, dass der Editor keine <p>
- oder <br/>
-Tags speichert. Die Zeilenumbrüche bleiben nicht erhalten.
Der TinyMCE ist folgendermaßen eingerichtet:
wp_tiny_mce(true, array('editor_selector' => $field['class'] ) );
'<textarea name="', $field['id'], '" class="', $field['class'], '" id="', $field['id'], '" cols="60" rows="8" style="width:97%">', $meta ? esc_html($meta) : $field['std'], '</textarea>';
Und das alles funktioniert einwandfrei. Alle Formatierungsschaltflächen außer den Tags <P>
und <BR>
funktionieren einwandfrei.
Ich bin nicht sicher, ob der Editor sie vor oder nach dem Speichern des Post-Metas entfernt.
Ideen?
Ich habe das kürzlich zum Laufen gebracht. Sie sollten metaname
suchen und durch Ihren Meta-Box-Namen ersetzen.
Der Schlüssel zur Aufrechterhaltung der Formatierung war die Verwendung von wpautop();
beim Speichern der Daten.
add_action( 'add_meta_boxes', 'add_metaname_box');
add_action( 'save_post', 'metaname_save');
function add_metaname_box() {
add_meta_box(
'metaname_id',
__( 'metaname text', 'metaname_textdomain'),
'metaname_custom_box',
'page'
);
}
function metaname_custom_box() {
global $post;
wp_nonce_field( plugin_basename( __FILE__ ), 'metaname_noncename' );
$data = get_post_meta($post->ID, 'metaname_custom_box', true);
echo <<<EOT
<script type="text/javascript">
jQuery(document).ready(function() {
jQuery("#metaname_custom_box").addClass("mceEditor");
if ( typeof( tinyMCE ) == "object" &&
typeof( tinyMCE.execCommand ) == "function" ) {
tinyMCE.execCommand("mceAddControl", false, "metaname_custom_box");
}
});
</script>
<textarea id="metaname_custom_box" name="metaname_custom_box">$data</textarea>
EOT;
}
function metaname_save($post_id) {
global $post;
// Verify
if ( !wp_verify_nonce( $_POST['metaname_noncename'], plugin_basename(__FILE__) )) {
return $post_id;
}
if ( 'page' == $_POST['post_type'] ) {
if ( !current_user_can( 'edit_page', $post_id ))
return $post_id;
} else {
if ( !current_user_can( 'edit_post', $post_id ))
return $post_id;
}
$key = 'metaname_custom_box';
$data = wpautop($_POST[$key]);
// New, Update, and Delete
if(get_post_meta($post_id, $key) == "")
add_post_meta($post_id, $key, $data, true);
elseif($data != get_post_meta($post_id, $key, true))
update_post_meta($post_id, $key, $data);
elseif($data == "")
delete_post_meta($post_id, $key, get_post_meta($post_id, $key, true));
}
Hier ist (eine abgespeckte Version von), was ich verwende, um TinyMCE individuell zu konfigurieren:
// http://tinymce.moxiecode.com/wiki.php/Configuration
function cbnet_tinymce_config( $init ) {
// Don't remove line breaks
$init['remove_linebreaks'] = false;
// Pass $init back to WordPress
return $init;
}
add_filter('tiny_mce_before_init', 'cbnet_tinymce_config');
Ich nehme an, das hast du schon versucht?
BEARBEITEN:
Möglicherweise müssen Sie einige andere Konfigurationsänderungen vornehmen, z. B .:
// Convert newline characters to BR tags
$init['convert_newlines_to_brs'] = true;
// Do not remove redundant BR tags
$init['remove_redundant_brs'] = false;
Spielen Sie mit den TinyMCE-Konfigurationsparametern und finden Sie den, den Sie ändern müssen.
Dies scheint sich in späteren Versionen von Wordpress ein wenig geändert zu haben. Sie können diese Funktionalität nun folgendermaßen deaktivieren:
add_filter('tiny_mce_before_init', function($init) {
$init['wpautop'] = false;
return $init;
}
Fand vielleicht eine einfachere Lösung dafür:
ändern Sie auf der tatsächlichen Vorlage Folgendes:
<?php echo get_the_content());?>
dazu:
<?php echo wpautop(get_the_content());?>
Auf diese Weise fügt wpautop ()die von TinyMCE entfernten Tags Template für Template hinzu.
warum benutzt du nicht die neue WordPress-Funktion wp_editor
, um den Tinymce zu rendern? Auf diese Weise wird alles erledigt. Und wenn Sie dem Benutzer den Inhalt zeigen, wenden Sie den Filter the_content
an.
So was:
$meta = "content of the metabox";
echo apply_filters('the_content', $meta);
Der Filter the_content
konvertiert die Verbindungsbremsen automatisch in <br>
und <p>
.
dies ist für diejenigen, die die Metaboxen für WordPress verwenden: Plugin-Name: Meta-Box Plugin-URI: deluxeblogtips com/meta-box
ich habe die Datei /vendor/meta-box/inc/fields/wysiwyg.php in der statischen Funktion geändert:
static function html( $html, $meta, $field )
//just after the else i have added :
$meta = html_entity_decode($meta); //
//and solve the problem ;)
- ABER DIE BESSERE LÖSUNG IS -
Gib dies in die Datei functions.php ein, sie ruft den Filter aus der Metabox Pluggin auf:
function meta_wysiwyg_antes_save($meta)
{
$meta = html_entity_decode($meta);
return $meta;
}
add_filter("rwmb_(ID-OF-METABOX-FIELD)_meta", "meta_wysiwyg_antes_save"); //en meta-box.php 194
Eine andere einfache Lösung: Verwenden Sie Shortcodes!
Fügen Sie diesen Code in die Datei functions.php ein und verwenden Sie [br] im Inhaltseditor (HTML oder Visual), wo immer ein br-Tag angezeigt werden soll.
add_shortcode("br", "br_tag");
function br_tag(){
return("<br/>");
}