- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
好的。我使用 TinyMCE 和 MarkJS 突出显示文本中的长单词。如果单词长度超过 6 个字母,则会被标记。
我在这里整理了一个演示:http://codepen.io/MarkBuskbjerg/pen/RomqKO
问题:
乍一看一切都很好。长单词完美突出显示。
但是...
如果将插入符号放在单词内。按下按键时突出显示消失。
示例:将插入符号放在文本末尾,然后按箭头键穿过文本,当插入符号位于突出显示的单词上时,突出显示就会消失。
我怀疑问题是由于当插入符位于单词上时 TinyMCE 触发某种事件。
可能的解决方案我试图看看插入符号是否以某种方式分割了单词,从而使其看起来更短。事实似乎并非如此(请参阅第 24 行的 console.log(words)。
** 编辑 2016 年 12 月 30 日:**当插入符号位于单词内部时,似乎应该是 TinyMCE 触发错误。也许是因为它执行了其他一些事件?
我的问题我不知何故需要找到一种方法来保持单词突出显示,同时插入符号在突出显示的范围内处于事件状态。
非常感谢任何关于如何实现这一目标的想法:)
HTML 标记是:
<div class="container">
<div id="myTextArea" contenteditable="true">
Lorem ipsum dolores sit amet.
</div>
</div>
JavaScript 是这样的:
tinymce.init({
selector: '#myTextArea',
height: 200,
setup: function(ed) {
ed.on('keyup', myCustomInitInstance);
ed.on('paste', myCustomInitInstance);
ed.on('cut', myCustomInitInstance);
},
init_instance_callback: "myCustomInitInstance",
});
function myCustomInitInstance(inst) {
var rawText = tinyMCE.get('myTextArea').getContent({
format: 'text'
});
rawText = rawText.replace(/<([^>]+)>|[\.\+\?,\(\)"'\-\!\;\:]/ig, "");
var words = rawText.split(" ");
var matchWarning = [];
var longWord = 6;
var wordCounter;
var output;
for (var i = 0, len = words.length; i < len; i++) {
if (words[i].length > longWord) {
matchWarning.push(words[i]);
}
}
var editor = tinyMCE.activeEditor;
// Store the selection
var bookmark = editor.selection.getBookmark();
console.log(bookmark);
// Remove previous marks and add new ones
var $ctx = $(editor.getBody());
$ctx.unmark({
done: function() {
$ctx.mark(matchWarning, {
acrossElements: true,
//debug: true,
separateWordSearch: false
});
}
});
console.log(bookmark);
// Restore the selection
editor.selection.moveToBookmark(bookmark);
}
最佳答案
您的问题是您正在监听 keyup
事件,如果您使用箭头键导航,该事件也会被触发。在此事件监听器的回调函数中,您使用 .unmark()
删除了突出显示的术语,这就是突出显示消失的原因。
要解决此问题,您需要忽略箭头键的事件。我已经为你做了这件事。另外,我重构了您的示例以简化情况,删除了不必要的变量并使用了 TinyMCE v4 方法(您正在使用)。
tinymce.init({
selector: "#myTextArea",
height: 200,
setup: function(editor) {
editor.on("init keyup", function(e) {
var code = (e.keyCode || e.which || 0);
// do nothing if it's an arrow key
if (code == 37 || code == 38 || code == 39 || code == 40) {
return;
}
myCustomInitInstance();
});
}
});
function myCustomInitInstance() {
var editor = tinymce.get("myTextArea"),
rawText = editor.getContent({
format: "text"
}).replace(/<([^>]+)>|[\.\+\?,\(\)"'\-\!\;\:]/ig, ""),
words = rawText.split(" "),
matchWarning = [],
longWord = 6;
for (var i = 0, len = words.length; i < len; i++) {
if (words[i].length > longWord) {
matchWarning.push(words[i]);
}
}
console.log(matchWarning);
var bookmark = editor.selection.getBookmark();
var $ctx = $(editor.getBody());
$ctx.unmark({
done: function() {
$ctx.mark(matchWarning, {
acrossElements: true,
separateWordSearch: false,
done: function() {
editor.selection.moveToBookmark(bookmark);
}
});
}
});
}
关于javascript - 当插入符号在文本上处于事件状态时,markjs.io 和 TinyMCE 书 checkout 现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41325148/
IO 设备如何知道属于它的内存中的值在memory mapped IO 中发生了变化? ? 例如,假设内存地址 0 专用于保存 VGA 设备的背景颜色。当我们更改 memory[0] 中的值时,VGA
我目前正在开发一个使用Facebook sdk登录(通过FBLoginView)的iOS应用。 一切正常,除了那些拥有较旧版本的facebook的人。 当他们按下“使用Facebook登录”按钮时,他
假设我有: this - is an - example - with some - dashesNSRange将使用`rangeOfString:@“-”拾取“-”的第一个实例,但是如果我只想要最后
Card.io SDK提供以下详细信息: 卡号,有效期,月份,年份,CVV和邮政编码。 如何从此SDK获取国家名称。 - (void)userDidProvideCreditCardInfo:(Car
iOS 应用程序如何从网络服务下载图片并在安装过程中将它们安装到用户的 iOS 设备上?可能吗? 最佳答案 您无法控制应用在用户设备上的安装,因此无法在安装过程中下载其他数据。 只需在安装后首次启动应
我曾经开发过一款企业版 iOS 产品,我们公司曾将其出售给大型企业,供他们的员工使用。 该应用程序通过 AppStore 提供,企业用户获得了公司特定的配置文件(包含应用程序配置文件)以启用他们有权使
我正在尝试将 Card.io SDK 集成到我的 iOS 应用程序中。我想为 CardIO ui 做一个简单的本地化,如更改取消按钮标题或“在此保留信用卡”提示文本。 我在 github 上找到了这个
我正在使用 CardIOView 和 CardIOViewDelegate 类,没有可以设置为 YES 的 BOOL 来扫描 collectCardholderName。我可以看到它在 CardIOP
我有一个集成了通话工具包的 voip 应用程序。每次我从我的 voip 应用程序调用时,都会在 native 电话应用程序中创建一个新的最近通话记录。我在 voip 应用程序中也有自定义联系人(电话应
iOS 应用程序如何知道应用程序打开时屏幕上是否已经有键盘?应用程序运行后,它可以接收键盘显示/隐藏通知。但是,如果应用程序在分屏模式下作为辅助应用程序打开,而主应用程序已经显示键盘,则辅助应用程序不
我在模拟器中收到以下错误: ImageIO: CGImageReadSessionGetCachedImageBlockData *** CGImageReadSessionGetCachedIm
如 Apple 文档所示,可以通过 EAAccessory Framework 与经过认证的配件(由 Apple 认证)进行通信。但是我有点困惑,因为一些帖子告诉我它也可以通过 CoreBluetoo
尽管现在的调试器已经很不错了,但有时找出应用程序中正在发生的事情的最好方法仍然是古老的 NSLog。当您连接到计算机时,这样做很容易; Xcode 会帮助弹出日志查看器面板,然后就可以了。当您不在办公
在我的 iOS 应用程序中,我定义了一些兴趣点。其中一些有一个 Kontakt.io 信标的名称,它绑定(bind)到一个特定的 PoI(我的意思是通常贴在信标标签上的名称)。现在我想在附近发现信标,
我正在为警报提示创建一个 trigger.io 插件。尝试从警报提示返回数据。这是我的代码: // Prompt + (void)show_prompt:(ForgeTask*)task{
您好,我是 Apple iOS 的新手。我阅读并搜索了很多关于推送通知的文章,但我没有发现任何关于 APNS 从 io4 到 ios 6 的新更新的信息。任何人都可以向我提供 APNS 如何在 ios
UITabBar 的高度似乎在 iOS 7 和 8/9/10/11 之间发生了变化。我发布这个问题是为了让其他人轻松找到答案。 那么:在 iPhone 和 iPad 上的 iOS 8/9/10/11
我想我可以针对不同的 iOS 版本使用不同的 Storyboard。 由于 UI 的差异,我将创建下一个 Storyboard: Main_iPhone.storyboard Main_iPad.st
我正在写一些东西,我将使用设备的 iTunes 库中的一部分音轨来覆盖 2 个视频的组合,例如: AVMutableComposition* mixComposition = [[AVMutableC
我创建了一个简单的 iOS 程序,可以顺利编译并在 iPad 模拟器上运行良好。当我告诉 XCode 4 使用我连接的 iPad 设备时,无法编译相同的程序。问题似乎是当我尝试使用附加的 iPad 时
我是一名优秀的程序员,十分优秀!