Как передать данные в базу данных с помощью WYSIWYG HTML Javascript Editor с Django.
После многих проб и ошибок я застрял. Я пытаюсь создать свой собственный редактор WYSIWYG с Django. Я создал WYSIWYG-редактор, но я просто не могу понять, как вообще включить мою форму редактора /HTML/Django. Вот мой HTML:
<!DOCTYPE html>
{% extends "base1.html" %}
<title>{% block title %} Create Information {% endblock %}</title>
{% block body_block %}
<form method="POST" enctype="multipart/form-data" autocomplete=off>
<style>
div#textEditor{ margin: 0 auto; width: 750px; height: 300px; }
div#theRibbon{ border-bottom: none; padding: 10px; background-color: rgb(40,110,89); color: white; border-radius: 8px 8px 0px 0px; }
div#richTextArea{ border: 2px solid rgb(40,110,89); height: 100%; width: 746px; background-color: white; }
iframe#theWYSIWYG{ height: 100%; width: 100%; }
div#theRibbon > button { color: white; border: none; outline: none; background-color: transparent; cursor: pointer; }
div#theRibbon > button:hover{ background-color: rgb(20,90,70); transition: all 0.3s linear 0s; }
input[type="color"]{ border: none; outline: none; background-color: transparent; }
</style>
<script> window.addEventListener("load",function(){ var editor = theWYSIWYG.document; editor.designMode = "on"; boldButton.addEventListener("click", function(){ editor.execCommand("Bold", false, null); },false);
italicButton.addEventListener("click", function(){ editor.execCommand("Italic", false, null); },false);
supButton.addEventListener("click", function(){ editor.execCommand("Superscript", false, null); },false);
subButton.addEventListener("click", function(){ editor.execCommand("Subscript", false, null); },false);
strikeButton.addEventListener("click", function(){ editor.execCommand("Strikethrough", false, null); },false);
orderedListButton.addEventListener("click", function(){ editor.execCommand("InsertOrderedList", false, "newOL" + Math.round(Math.random() * 1000)); },false);
unorderedListButton.addEventListener("click", function(){ editor.execCommand("InsertUnorderedList", false, "newOL" + Math.round(Math.random() * 1000)); },false);
fontColorButton.addEventListener("change", function(event){ editor.execCommand("ForeColor", false, event.target.value); },false);
highlightButton.addEventListener("change", function(event){ editor.execCommand("BackColor", false, event.target.value); },false);
fontChanger.addEventListener("change", function(event){ editor.execCommand("FontName", false, event.target.value); },false);
fontSizeChanger.addEventListener("change",function(event){ editor.execCommand("FontSize",false,event.target.value); },false);
linkButton.addEventListener("click", function(){ var url = prompt("Enter a URL", "http://"); editor.execCommand("CreateLink", false, url); }, false);
unLinkButton.addEventListener("click",function(){ editor.execCommand("UnLink",false,null); },false);
undoButton.addEventListener("click",function(){ editor.execCommand("undo",false,null); },false);
redoButton.addEventListener("click",function(){ editor.execCommand("redo",false,null); },false);
submitButton.addEventListener("click",function(){ richText.value = theWYSIWYG.document.body.innerHTML; theForm.submit(); },false); },false);
</script>
{% csrf_token %}
<div class="box3">
<h2 class="title">Create New Information</h2>
<label class="label6">New Information</label>
<div id="textEditor">
<div id="theRibbon">
<button id="boldButton" title="Bold"><b>B</b></button>
<button id="italicButton" title="Italic"><em>I</em></button>
<button id="supButton" title="Superscript">X<sup>2</sup></button>
<button id="subButton" title="Subscript">X<sub>2</sub></button>
<button id="strikeButton" title="Strikethrough"><s>abc</s></button>
<button id="orderedListButton" title="Numbered list">(i)</button>
<button id="unorderedListButton" title="Bulleted list"">•</button>
<input type="color" id="fontColorButton" title="Change Font Color">
<input type="color" id="highlightButton" title="Highlight Text">
<select id="fontChanger">
<option value="Times New Roman">Times New Roman</option>
<option value="Consolas">Consolas</option>
<option value="Tahoma">Tahoma</option>
<option value="monospace">Monospace</option>
<option value="cursive">Cursive</option>
<option value="sans-serif">Sans-Serif</option>
<option value="Calibri">Calibri</option>
</select>
<select id="fontSizeChanger">
<script> for(var i = 1; i < 10; i++){ document.write("<option value='"+i+"'>"+i+"</option>"); }
</script>
</select>
<script> var fonts = document.querySelectorAll("select#fontChanger > option"); for(var i = 0; i < fonts.length; i++){ fonts[i].style.fontFamily = fonts[i].value; }
</script>
<button id="linkButton" title="Create Link">Link</button>
<button id="unLinkButton" title="Remove Link">Unlink</button>
<button id="undoButton" title="Undo the previous action">←</button>
<button id="redoButton" title="Redo">→</button>
</div>
<div id="richTextArea">
<iframe id="theWYSIWYG" name="theWYSIWYG" frameborder="0">
<textarea name="newinformation">{{ form.newinformation }}</textarea>
</iframe>
</div>
</div>
Форма отображается правильно, но в конечном итоге я получаю следующую ошибку "пустое значение в столбце" новая информация "нарушает ненулевое ограничение при отправке формы. Моя модель определена правильно. По сути, данные, которые я помещаю в WYSIWYG, не являются Передача в базу данных. Я использую отдельные поля в своей форме, и я не могу понять, как по существу объединить редактор WYSIWYG и мое поле {{ form.newinformation }}. Я включил в свой код form.newinformation Пример выше, чтобы показать, что я пытался, но это не работает.
Заранее спасибо за любые идеи.
1 ответ
Ваш HTML неверен.
Ваша форма не закрывается, и вы помещаете свой вклад в iFrame.
поэтому, когда вы размещаете свою форму, содержимое iFrame не публикуется на сервере.