Вопрос проверки TinyMCE jQuery - PullRequest
1 голос
/ 27 июня 2011

Я использую простой TinyMCE для своей страницы. Возникла проблема, когда я проверял свою текстовую область с помощью jQuery.

jQuery не подтвердил мою текстовую область.

  1. Сохраняем пустой текст
  2. Упомянуто (". Не оставляйте текстовую область пустой") Ошибка возникает при записи чего-либо в TextArea.

Это мой код:

<------------------------------------------------------->
jQuery code:
<------------------------------------------------------->
<script type="text/javascript">
$(document).ready(function() {
    $("#frmeditpages").validate({
        rules: {
            txtdescription:
            {
                required:true
            }

                },
        messages: {
            txtdescription: ".       Don't leave the Text area Empty"

                  }
    });
});
</script>
<----------------------------------------------------------->
<!-- TinyMCE -->
<----------------------------------------------------------->

<script type="text/javascript" src="../js/jquery-lib.js"></script>  
<script type="text/javascript" src="../js/jquery.validate.js"></script>
<script type="text/javascript" src="../tinymce/jscripts/tiny_mce/tiny_mce.js"></script>

<script type="text/javascript">
    tinyMCE.init({
        // General options
        mode : "textareas",
        theme : "simple",
        plugins : "pagebreak,style,layer,table,save,advhr,advimage,advlink,emotions,iespell,inlinepopups,insertdatetime,preview,media,searchreplace,print,contextmenu,paste,directionality,fullscreen,noneditable,visualchars,nonbreaking,xhtmlxtras,template,wordcount,advlist,autosave",

        // Theme options
        theme_advanced_buttons1 : "save,newdocument,|,bold,italic,underline,strikethrough,|,justifyleft,justifycenter,justifyright,justifyfull,styleselect,formatselect,fontselect,fontsizeselect",
        theme_advanced_buttons2 : "cut,copy,paste,pastetext,pasteword,|,search,replace,|,bullist,numlist,|,outdent,indent,blockquote,|,undo,redo,|,link,unlink,anchor,image,cleanup,help,code,|,insertdate,inserttime,preview,|,forecolor,backcolor",
        theme_advanced_buttons3 : "tablecontrols,|,hr,removeformat,visualaid,|,sub,sup,|,charmap,emotions,iespell,media,advhr,|,print,|,ltr,rtl,|,fullscreen",
        theme_advanced_buttons4 : "insertlayer,moveforward,movebackward,absolute,|,styleprops,|,cite,abbr,acronym,del,ins,attribs,|,visualchars,nonbreaking,template,pagebreak,restoredraft",
        theme_advanced_toolbar_location : "top",
        theme_advanced_toolbar_align : "left",
        theme_advanced_statusbar_location : "bottom",
        theme_advanced_resizing : true,

        // Example content CSS (should be your site CSS)
        content_css : "css/content.css",

        // Drop lists for link/image/media/template dialogs
        template_external_list_url : "lists/template_list.js",
        external_link_list_url : "lists/link_list.js",
        external_image_list_url : "lists/image_list.js",
        media_external_list_url : "lists/media_list.js",

        // Style formats
        style_formats : [
            {title : 'Bold text', inline : 'b'},
            {title : 'Red text', inline : 'span', styles : {color : '#ff0000'}},
            {title : 'Red header', block : 'h1', styles : {color : '#ff0000'}},
            {title : 'Example 1', inline : 'span', classes : 'example1'},
            {title : 'Example 2', inline : 'span', classes : 'example2'},
            {title : 'Table styles'},
            {title : 'Table row 1', selector : 'tr', classes : 'tablerow1'}
        ],

        // Replace values for the template plugin
        template_replace_values : {
            username : "Some User",
            staffid : "991234"
        }
    });
</script>
<!-- /TinyMCE -->

Ответы [ 4 ]

1 голос
/ 27 июня 2011

Вы должны знать, что tinymce не равно текстовой области! Tinymce будет скрывать текстовую область при инициализации и создавать iframe, в котором пользователь может редактировать контент. Таким образом, необходимо вызвать метод сохранения tinymce, чтобы записать содержимое iframes обратно в текстовую область.

Итак, вам нужен следующий код

var editor = tinymce.get( editor_id);
editor.save();  // writes content back to the textarea
// you may now use jQuery or editor.getContent(); to acces the content
0 голосов
/ 07 сентября 2018

это происходит потому, что tinymce скрывает текстовую область.Чтобы решить проблему, поставьте это перед вызовом validate:

$(document).ready(function(){    
    $.validator.setDefaults({
        ignore: []
    });

    // validate call
});
0 голосов
/ 27 июня 2014

Следующий код работал для меня и для вас.Просто поместите следующий код перед вашими проверочными звонками, но после того, как отправка активирована

     var content = tinyMCE.activeEditor.getContent(); // get the content
     $('#textareaID').val(content);
     
0 голосов
/ 08 января 2014

Демонстративно работайте с этой логикой

$("#buttontosave").click(function() {
    tinyMCE.triggerSave();
    var status;
    status = $("#menu_create").valid(); //Validate again
   /* if(status==true)
    { 
       //alert('true')
    }
    else 
    { 
         //  alert('false')

    }*/

});

buttontosave ваш идентификатор кнопки подтверждения Примечание: плз проверить скрытые значения также, не делайте так

ignore: 'input[type="hidden"]',

Пожалуйста, оставьте комментарий

   //ignore: 'input[type="hidden"]',
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...