- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个编辑器实例。一个是可编辑的第二个只读,用于预览用户输入的内容我在这些编辑器之间复制了编辑器状态 - 没有任何问题但我想当第一个编辑器为空时隐藏第二个编辑器。我正在尝试类似的方法,但它总是返回 false
...
function onChange(editorState) {
console.log(editorState.isEmpty())
}
function Editor() {
...
return (
<>
<LexicalComposer initialConfig={editorConfig}>
<ToolbarPlugin />
<RichTextPlugin
contentEditable={<ContentEditable className="editor-input" />}
placeholder={<Placeholder />}
ErrorBoundary={LexicalErrorBoundary}
/>
<OnChangePlugin onChange={onChange} />
<LexicalComposer />
)
}
最佳答案
不幸的是,目前有几种不同的方法可以做到这一点,具体取决于您所说的“空”的含义。您可以使用 EditorState.isEmpty,但这是检查 _nodeMap 是否仅包含单个节点(根)并且选择是否为空 - 所以它实际上是关于空的,因为 EditorState 处于相同的状态如果它刚刚被初始化。然而,这可能不是您想要的 - 通常,视觉上空的编辑器将有一个带有单个 ParagraphNode 子级的 RootNode,并且您可能会或可能不关心 Selection 是否为空。因此,您可以考虑使用 ElementNode.isEmpty:
$getRoot().isEmpty()
这会检查 RootNode 是否有 0 个子节点。再说一遍,在典型的编辑器中,在很多情况下您希望它返回 true,这可能会返回 false(例如,如果编辑器在 RootNode 下使用空的 ParagraphNode 进行初始化)。所以,你可以这样做:
const isEditorEmpty = editorState.read(() => {
const root = $getRoot();
const isEmpty = root.getFirstChild().isEmpty() && root.getChildrenSize() === 1
return isEmpty;
});
但是,这不会解释空格 - 您可能也关心这一点。如果您想将只有空格的编辑器视为空,那么您可能需要使用 @lexical/text 中的 $isRootTextContentEmpty。您还可以查看此函数的实现,了解如何根据您的用例对其进行调整。
关于lexical - 如何检查编辑器是否为空?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/75493899/
我正在阅读有关 C# 和闭包的各种信息 articles ,Jon Skeet 的精彩“C# in Depth”,我看到像“C# 和 ruby 实现词法闭包”这样的陈述。 为什么作者要包含“词汇”
我有两个编辑器实例。一个是可编辑的第二个只读,用于预览用户输入的内容我在这些编辑器之间复制了编辑器状态 - 没有任何问题但我想当第一个编辑器为空时隐藏第二个编辑器。我正在尝试类似的方法,但它总是返回
我正在使用 Flex 构建自己的语言,但我想知道一些事情: 为什么要使用词法分析器? 他们会帮我做点什么吗? 他们是强制性的吗? 最佳答案 词法分析有助于简化解析,因为词位可以被视为抽象实体而不是具体
考虑到一个二进制数据(视频/图像/音频/可执行文件)可以看作是一长串随机字节, 当数据采用特殊格式(SQL、数据库中的 BOLB、MP3、JSON、XML 等)时,解析器如何知道特殊字符(或字符序列,
我对 javascript 中的 this 有疑问。 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operato
我使用术语“词法编码”是因为我没有更好的编码。 与字母相反,单词可以说是交流的基本单位。 Unicode 尝试为所有已知字母表的每个字母分配一个数值。对一种语言来说是字母,对另一种语言来说是字形。 U
我一直在用 Java 编写一个语音识别程序,只是为了看看它是如何工作的。直到一天前一切都工作得很好。我不知道发生了什么,因为我没有更改代码中的任何内容。 由于出现词汇错误,我想我只需要粘贴我的语法文件
在调试一些较旧的 perl 代码时,我使用 perl critic 来发现错误。我经常偶然发现这个“循环迭代器不是词法”策略: Perl::Critic::Policy::Variables::Req
在 perdoc Socket页,他们使用全局文件句柄作为套接字。 但是如果我在子进程调用的子例程中创建一个套接字,使用词法文件句柄仍然使用 Socket 是否更好? 像这样: use strict;
我正在尝试为我出于个人原因而设计的 C/C++/C#/Java/D 之类的编程语言编写扫描仪。对于这个任务,我使用 Ragel 来生成我的扫描仪。我无法准确理解许多操作符何时触发 Action ,可能
我是 AI 学生,我们使用 JavaCC。 我是新手。我正在尝试简单的例子,但我有一些错误。 1)我从它的网站下载了 JavaCC 0.6 2)我把它解压到C盘 3)我将此代码写在扩展名为“.jj”的
在@lexical/react中,在没有依赖数组的useEffect中注册编辑器命令是否会带来重大损失(性能或其他)? useEffect(() => { const unsubscribe =
我有一个词法编辑器,需要将其序列化为 html,以便我可以将其嵌入到电子邮件模板中。 使用 $generateHtmlFromNodes 函数时,我不断遇到以下错误: Error: Unable to
在经典的编译器理论中,前两个阶段是词法分析和语法分析。他们正在筹备中。词法分析将标记识别为解析的输入。 但是我遇到了一些在词法分析中很难被正确识别的情况。例如下面关于C++模板的代码: map> >>
let textBytes = ctypes.uint8_t("hello"); let a = new SECItem; a.type = siBuffer; a.data = textBytes.
我有4条规则 rule1: match variable rule2: match Float rule3: match Integer rule4: [ \t] ; //skipping space
如果您查看 original Wordnet search并选择“显示选项:显示词汇文件信息”,您将看到一个非常有用的单词分类,称为 词汇文件 .例如,对于“填充”,我们有: S: (n) fi
我已经多次看到术语“词法变量”,主要是在闭包的上下文中。 Paul Graham 在他关于 Lisp 的书中使用这个术语来指代使用 let 表达式定义的变量。 我知道词法作用域是静态作用域的另一个名称
应用程序版本 Elasticsearch:v.7.1 Laravel:v5.8 操作系统版本:Ubuntu 18(服务器)/ Windows 10(开发PC) Elasticsearch搜索API的“
我想以 myObj 作为其运行范围来调用 myObj.sayHello。我了解绑定(bind),它工作得很好。 var myObj = {"name1":"BP", "sayHell
我是一名优秀的程序员,十分优秀!