我为summernote设置了一个div来改变从数据库中提取的文本。
<div id="summernote" class="form-control"><?php echo $laws['content']; ?></div>
$(document).ready(function() {
$('#summernote').summernote({
height: 300,
});
});
直接在div后面我有一个带ID的文本区域。
<textarea id="lawsContent"></textarea>
当我在summernote div中输入时,我希望textarea的内容发生变化。就像我在输入这个问题时发生的事情一样。
答案 0 :(得分:16)
我提出了这个解决方案:
$(document).ready(function() {
$('#summernote').summernote({
onKeyup: function(e) {
$("#lawsContent").val($("#summernote").code());
},
height: 300,
});
});
答案 1 :(得分:9)
我认为最好处理onChange事件。
<强> v0.7.0 强>
$('#summernote').summernote({
callbacks: {
onChange: function(contents, $editable) {
console.log('onChange:', contents, $editable);
}
}
});
$(document).ready(function(){
$("#summernote").summernote(
{
height: "10em",
callbacks: {
onChange: function (contents, $editable) {
var code = $(this).summernote("code");
$("#lawsContent").val(code);
}
}
}
);
});
#lawsContent
{
width: 100%;
height: 10em;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.7.0/summernote.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet"/>
<link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.3.0/css/font-awesome.css" rel="stylesheet"/>
<link href="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.7.0/summernote.min.css" rel="stylesheet"/>
Editor:
<div id="summernote" class="form-control"></div>
Output:
<textarea id="lawsContent" class="form-control"></textarea>
<强> v0.6.5 强>
截至此版本,callback only works with camel case string。
$('#summernote').summernote({
onChange: function(contents, $editable) {
console.log('onChange:', contents, $editable);
}
});
$(document).ready(function(){
$("#summernote").summernote(
{
height: "10em",
onChange: function (contents, $editable) {
$("#lawsContent").val(contents);
}
}
);
});
#lawsContent
{
width: 100%;
height: 10em;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.6.7/summernote.min.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.3.0/css/font-awesome.css" rel="stylesheet"/>
<link href="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.6.7/summernote.min.css" rel="stylesheet"/>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"/>
Editor:
<div id="summernote" class="form-control"></div>
Output:
<textarea id="lawsContent" class="form-control"></textarea>
答案 2 :(得分:6)
受@ user3367639的启发,这是一种更通用的方法
$('.summernote').each(function () {
var $textArea = $(this);
$textArea.summernote({
onKeyup: function (e) {
$textArea.val($(this).code());
$textArea.change(); //To update any action binded on the control
}
});
});
用这种方法:
String.prototype.strip = function()
{
var tmpDiv = document.createElement("div");
tmpDiv.innerHTML = this;
return tmpDiv.textContent || tmpDiv.innerText || "";
}
您可以在JS控制器中执行类似这样的操作来获取textarea的文本值
$myTextArea.val().strip(); //Where val() returns the html and strip() returns the text
希望这会有所帮助
答案 3 :(得分:2)
使用此示例:
<form id="form_id" action="/summernote.php" onsubmit="return postForm()">
<textarea id="summernote" rows="6" name="textarea_name" ></textarea>
</form>
<script type="text/javascript">
$(document).ready(function(){
var postForm = function() {
var content = $('textarea[name="textarea_name"]').html($('#summernote').code());
}
});
</script>
答案 4 :(得分:0)
<div role="tabpanel" class="tab-pane" id="product_desc_l">
<p>
First impressions are everything. <br> <br>
</p>
<strong>Features:</strong>
</div>
<textarea id="product_desc_long" name="product_desc_long" class="summernote form-control" rows="10" placeholder="Enter the product long description..."></textarea>
$(document).ready(function() {
$('.summernote').summernote({
height: 300,
onKeyup: function(e) {
$("#product_desc_l").html($(this).code());
}
});
});
这对我有用
答案 5 :(得分:0)
$('textarea').summernote({
callbacks: {
onChange: function(contents, $editable) {
console.log('onChange:', contents, $editable);
}
}
})
<form>
<textarea name="content" onChange></textarea>
</form>