- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Froala 编辑器实现一些自定义放置事件功能。他们在 codepen 上有一个非常基本的例子:Drag Drop Example
问题是这不起作用 - 我无法触发自定义“froalaEditor.drop”函数,我确信我需要在某处为 HTML5 放置事件添加某种“防止默认”但我所做的一切已经尝试过要么终止所有掉落功能,要么什么都不做。自定义函数如下所示:
$('div#froala-editor').froalaEditor({
toolbarButtons: ['bold', 'italic', 'underline', 'insertImage', 'insertLink', 'emoticons', 'undo', 'redo'],
pluginsEnabled: ['image', 'link', 'draggable', 'emoticons']
})
.on ('froalaEditor.drop', function (e, editor, dropEvent) {
//// do stuff - nothing is firing
我正在通过标准使其可拖动:
draggable="true"
如有任何帮助或指点,我们将不胜感激!
谢谢,
标记
更新:::
这是我的 JS:
$(function() {
// For Firefox to work.
$("#drag-smile, #drag-text").on("dragstart", function(e) {
e.originalEvent.dataTransfer.setData("Text", this.id);
});
$("div#froala-editor")
.froalaEditor({
toolbarButtons: [
"bold",
"italic",
"underline",
"insertImage",
"insertLink",
"emoticons",
"undo",
"redo"
],
pluginsEnabled: ["image", "link", "draggable", "emoticons"]
})
.on("froalaEditor.drop", function(e, editor, dropEvent) {
// Focus at the current posisiton.
editor.markers.insertAtPoint(dropEvent.originalEvent);
var $marker = editor.$el.find(".fr-marker");
$marker.replaceWith($.FroalaEditor.MARKERS);
editor.selection.restore();
// Save into undo stack the current position.
if (!editor.undo.canDo()) editor.undo.saveStep();
// Insert HTML.
if (dropEvent.originalEvent.dataTransfer.getData("Text") == "drag-smile") {
editor.html.insert(
'<span class="fr-emoticon fr-emoticon-img" style="background: url(https://cdnjs.cloudflare.com/ajax/libs/emojione/2.0.1/assets/svg/1f600.svg)"> </span>'
);
} else {
editor.html.insert("Hello!");
}
// Save into undo stack the changes.
editor.undo.saveStep();
// Stop event propagation.
dropEvent.preventDefault();
dropEvent.stopPropagation();
return false;
});
});
还有我的 HTML:
<div id="drag-smile" style="border: solid 1px #CCC; padding: 5px; width: 300px;" draggable="true"><img src="https://cdnjs.cloudflare.com/ajax/libs/emojione/2.0.1/assets/svg/1f600.svg" width="32" /> Drag Me to insert a smile.</div><br/>
<div id="drag-text" style="border: solid 1px #CCC; padding: 5px; width: 300px;" draggable="true">Drag Me to insert some text.</div><br/>
<div id="froala-editor">
<h3>Click here to edit the content</h3>
<p>The image can be dragged only between blocks and not inside them.
</p>
</div>
基本上,当您将其中一个可拖动的 div 拖到编辑器中时,应该将自定义 html 注入(inject)到编辑器中,但它只是将 div id 添加为文本。
最佳答案
那是因为 drop 事件在到达您的回调之前被停止了。像这样更改它以确保始终首先调用您的事件:
$("div#froala-editor")
.on("froalaEditor.initialized", function(e, editor, dropEvent) {
editor.events.on('drop', function (dropEvent) {
// Focus at the current posisiton.
editor.markers.insertAtPoint(dropEvent.originalEvent);
var $marker = editor.$el.find(".fr-marker");
$marker.replaceWith($.FroalaEditor.MARKERS);
editor.selection.restore();
// Save into undo stack the current position.
if (!editor.undo.canDo()) editor.undo.saveStep();
// Insert HTML.
if (dropEvent.originalEvent.dataTransfer.getData("Text") == "drag-smile") {
editor.html.insert(
'<span class="fr-emoticon fr-emoticon-img" style="background: url(https://cdnjs.cloudflare.com/ajax/libs/emojione/2.0.1/assets/svg/1f600.svg)"> </span>'
);
} else {
editor.html.insert("Hello!");
}
// Save into undo stack the changes.
editor.undo.saveStep();
// Stop event propagation.
dropEvent.preventDefault();
dropEvent.stopPropagation();
return false;
}, true);
});
.froalaEditor({
toolbarButtons: [
"bold",
"italic",
"underline",
"insertImage",
"insertLink",
"emoticons",
"undo",
"redo"
],
pluginsEnabled: ["image", "link", "draggable", "emoticons"]
})
});
关于javascript - Froala 编辑器/拖放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43900702/
我想像 wordpress 的 css 管理器一样为我的网站制作 css 管理器。我想在 textarea 中打开 css 文件,这样我就可以编辑它,而不是在按下提交按钮后,应该保存 css 文件中的
我不知道这是一个有效的问题。我见过大多数插件和对话框定义的 CKEditor 示例都使用变量“editor”。我想知道它是什么以及它的值来自哪里。 例如 CKEDITOR.plugins.add( '
前言 今天大姚给大家分享一个基于 Roslyn 和 AvalonEdit 开源、轻量、跨平台的 C# 编辑器:RoslynPad。 Roslyn介绍 Roslyn是一个强大的.NET编译器实现,
如果你希望极认真地学习和使用 XML,那么一定想要找一款称手的 XML 编辑器 XML 是基于文本的 XML是基于文本的标记语言 XML可被类似记事本这样的简单的文本编辑器来创建和编辑 不过在
有没有人成功地将 Summernote 编辑器与 Meteor 一起使用? 见 http://hackerwins.github.io/summernote/ 我在我的模板中包含了以下 div:
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
如何使文本默认从右向左对齐(p:editor)。 当前使用 primefaces 3.0.M2-SNAPSHOT。现在无法更新到新版本吗? 这是阿拉伯语版本应用程序所必需的。 谢谢 最佳答案 在 we
如何启动或安装 Eclipse XSD 编辑器? 根据this看来它应该开箱即用。我创建了 XMLExamples 项目,当我打开 Catalogue.xsd 时,Eclipse 将其视为文本文件。如
我爱wysihtml5但我找不到任何关于向元素添加类这样简单的文档。 基本上我正在寻找的是一种允许 blockquote 元素有 2 种不同变体的方法: blockquote.pull-leftblo
我真的很想要一个在 Django 中实现文本编辑器的清晰直接的示例,就像提议的 pagedown 或 markdownx 一样。我无法在 Django 2.0 中使用这些解决方案中的任何一个,并且我找
是否有支持 REPL 和大括号匹配的 ClojureCLR 编辑器?我找到了一个将对 ClojureCLR 的支持添加到 Visual Studio 的项目:vsClojure ,但无法构建它。还有其
GWT 的编辑器框架非常好用,它不仅可以用于编辑POJO,还可以用于只读显示。 但是,我并不完全确定进行内联编辑的最佳做法是什么。 假设我有一个 PersonProxy 并且我有一对 Presente
我对 primefaces 编辑器的第一个问题是它不接受来自 Chrome 和资源管理器中的 MS word 文档的文本,但在 Firefox 中工作正常。有没有办法让它直接接受来自 MS word
我使用 Prototype JS 作为主要 JS 库,并且我已将最后一个 RedactorJS 与 jQuery 以无冲突模式集成,但我无法启动如下功能: jQuery('#redactor').re
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
我正在 Laravel 项目上使用 redactor 作为文本编辑器。 每当编辑器位于页面上并初始化时,每当我单击任意位置时都会收到此错误。 Uncaught TypeError: $(...).cl
我在带有 jQuery .show("slide") 动画的界面设计中使用tinyMCE 时遇到问题。由于表单的复杂性,它像向导一样被分为多个页面,但它不使用下一步和后退按钮。相反,它使用部分名称
如何制作像 wufoo.com 表单编辑器中那样的拖放式编辑器 最佳答案 通常客户端应用程序是使用某种客户端框架构建的。比较流行的是(排名不分先后): GWT YUI jQuery 首先检查这些内容,
已关闭。此问题旨在寻求有关书籍、工具、软件库等的建议。不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以
有人建议我使用具有语法错误检查和调试功能的 Javascript 编辑器吗? Eclipse IDE 有可用的插件吗?或者您可以建议最适合错误检查和调试的任何编辑器。 提前致谢。 最佳答案 您可以安装
我是一名优秀的程序员,十分优秀!