Lấy giá trị, gán giá trị và cập nhật giá trị của CKEditor bằng Javascript

by My Love

24/05/2019, 8:57 AM   |    29/05/2019, 3:01 PM   |    2.6K   |    0

      Trong nhiều trường hợp bạn muốn lấy giá trị của CKEditor nhưng nó lại trả về rỗng. Hay bạn sử dụng ASP.Net với Webfrom giá trị của CKEditor luôn rỗng trong code behind thì có thể tham khảo cách đơn giản sau đây :

1. Lấy giá trị, gán giá trị của CKEditor với getData() và setData()
      Ví dụ bạn có một <textarea> và chèn CKEditor vào như sau :
<textarea id="TextID"></textarea>
<input id="Save" type="submit" value="TEST"/>
<script>		
     CKEDITOR.replace("TextID");
</script>
- Bây giờ khi bạn lấy giá trị của CKEditor theo cách thông thường như sau sẽ trả về rỗng, mặc dù bạn có nhập dữ liệu văn bản vào CKEditor rồi :
<script language="javascript">
     $(document).ready(function(){
	 $('#Save').on('click', function(){	
					
             // Trả về rỗng
	     alert($('#TextID').val());
				
	});
    });
</script>
- Để giải quyết vấn đề này đơn giản bạn có 2 cách. Cách 1 sử dụng getData() để lấy giữ liệu của CKEditor như sau :
<html>
    <head>
        <script language="javascript" src="https://code.jquery.com/jquery-3.1.1.min.js"></script>  
		<script  src="http://localhost/ckeditor4_full/ckeditor/ckeditor.js"></script>		
       
        <script language="javascript">
            $(document).ready(function(){
				$('#Save').on('click', function(){
					
					var value = CKEDITOR.instances['TextID'].getData()	
					// alert ra kết quả
					alert(value );
				
				});
            });
        </script>
    </head>
    <body>
       <textarea id="TextID"></textarea>
	   <script>
			CKEDITOR.replace("TextID");
	   </script>
       <input id="Save" type="submit" value="TEST"/>
    </body>
</html>
Thay vì sử dụng hàm val() của jQuery thì bạn sử dụng getData() sẽ lấy được giá trị của CKEditor.

- Ngược lại với getData() bạn có thể gán dữ liệu cho CKEditor với setData()
// với TextID là id của <textarea> CKEditor, value là giá trị muốn gán vào
CKEDITOR.instances['TextID'].setData(value);


- Cách 2 bạn có thể cập nhật CKEditor với hàm updateElement() trước khi lấy giá tri như sau.

2. Cập nhật giá trị CKEditor
     Để cập nhật giá trị của CKEditor ta sử dụng updateElement() như sau :
- Nếu có nhiều CKEditor bạn có thể dùng for :
for(var instanceName in CKEDITOR.instances)
    CKEDITOR.instances[instanceName].updateElement();
- Hoặc nếu bạn muốn chỉ định một CKEditor  nào đó có thể dùng như sau, với TextID id của <textarea> :
CKEDITOR.instances['TextID'].updateElement();
 
<html>
    <head>
        <script language="javascript" src="https://code.jquery.com/jquery-3.1.1.min.js"></script>  
		<script  src="http://localhost/ckeditor4_full/ckeditor/ckeditor.js"></script>		
       
        <script language="javascript">
            $(document).ready(function(){
				$('#Save').on('click', function(){
					for ( instance in CKEDITOR.instances )
						CKEDITOR.instances[instanceName].updateElement();
					
					alert($('#TextID').val());
				
				});
            });
        </script>
    </head>
    <body>
       <textarea id="TextID"></textarea>
	   <script>
			CKEDITOR.replace("TextID");
	   </script>
       <input id="Save" type="submit" value="TEST"/>
    </body>
</html>


- Nếu bạn sử dụng updateElement() mà vẫn không được, thì có thể dùng cách sau :
        <script language="javascript">
            $(document).ready(function(){
				// với TextID là id của <textarea> CKEditor
				
					CKEDITOR.instances['TextID'].on("instanceReady", function () {
						//set keyup event
						this.document.on("keyup", function () {
							CKEDITOR.tools.setTimeout(function () {
								$('#TextID').val(CKEDITOR.instances['TextID'].getData());
							}, 0);
								
						});

						//and paste event
						this.document.on("paste", function () {
							CKEDITOR.tools.setTimeout(function () {
								$('#TextID').val(CKEDITOR.instances['TextID'].getData());
							}, 0);
								 
						});
						//and cut event
						this.document.on("cut", function () {
							CKEDITOR.tools.setTimeout(function () {
								$('#TextID').val(CKEDITOR.instances['TextID'].getData());
						}, 0);
								 
						});
					 });
				
            });
        </script>
- Nếu trong trang của bạn có nhiều CKEditor thì có thể dùng cách sau :
        $(document).ready(function () {
            // MyClass là tên class của các <textarea> CKEditor
            $('.MyClass').each(function () {
                var ID = $(this).attr('id');
                CKEDITOR.instances[ID].on("instanceReady", function () {
                    //set keyup event
                    this.document.on("keyup", function () {
                        CKEDITOR.tools.setTimeout(function () {
                            $("#" + ID).val(CKEDITOR.instances[ID].getData());
                        }, 0);
                    });

                     //and paste event
                     this.document.on("paste", function () {
                         CKEDITOR.tools.setTimeout(function () {
                             $("#" + ID).val(CKEDITOR.instances[ID].getData());
                         }, 0);
                     });

                    //and cut event
                     this.document.on("cut", function () {
                         CKEDITOR.tools.setTimeout(function () {
                             $("#" + ID).val(CKEDITOR.instances[ID].getData());
                         }, 0);

                     });
                 });
            });
           
        });

Lưu Ý: một chú ý nhỏ với ai dùng ASP.Net Webform là khi thao tác gán CKEditor vào <asp:TexBbox></asp:TextBox> thì nên để TextMode="MultiLine" nếu không khi lấy dữ liệu từ CSDL gán vào CKEditor sẽ không được, trước mình không chú ý rất hay gặp lỗi này.

- Với việc cập nhật giá trị cho CKEditor như trên sẽ giúp lấy về được giá trị của nó, chúc bạn thành công !