Skip to content

添加事件处理器

好的,你已经安装了 Slate 并且在页面上渲染了出来。并且当你输入的时候,会看到发生的变化。但是你一定希望做更多而不是仅仅输入一些纯文本。

Slate 很棒的原因是你可以如此轻松地去定制它。就像是在其它 React 组件中你曾经那样做的一样,当某些事件触发的时候 Slate 允许你传递事件处理程序。

当我们按下按键时候,让我们使用 onKeyDown 事件去改变编辑器的内容。

这是我们之前的app:

jsx
const App = () => {
  const editor = useMemo(() => withReact(createEditor()), [])
  const [value, setValue] = useState([
    {
      type: 'paragraph',
      children: [{ text: '段落中的一行文本。' }],
    },
  ])

  return (
    <Slate editor={editor} value={value} onChange={value => setValue(value)}>
      <Editable />
    </Slate>
  )
}

现在让我们添加一个 onKeyDown 处理程序:

jsx
const App = () => {
  const editor = useMemo(() => withReact(createEditor()), [])
  const [value, setValue] = useState([
    {
      type: 'paragraph',
      children: [{ text: '段落中的一行文本。' }],
    },
  ])

  return (
    <Slate editor={editor} value={value} onChange={value => setValue(value)}>
      <Editable
        // 定义一个新的处理程序在控制台打印按下的键。
        onKeyDown={event => {
          console.log(event.key)
        }}
      />
    </Slate>
  )
}

非常棒!现在当我们在编辑器中按下按键,它相应的 keyCode 会被打印到控制台中。

现在我们想要让它实际上去改变内容。就我们的示例而言,让我们实现在输入时将所有的 & 转换为 and

我们的 onKeyDown 事件处理程序可能会是这个样子:

jsx
const App = () => {
  const editor = useMemo(() => withReact(createEditor()), [])
  const [value, setValue] = useState([
    {
      type: 'paragraph',
      children: [{ text: '段落中的一行文本。' }],
    },
  ])

  return (
    <Slate editor={editor} value={value} onChange={value => setValue(value)}>
      <Editable
        onKeyDown={event => {
          if (event.key === '&') {
            // 阻止插入 `&` 字符的默认事件。
            event.preventDefault()
            // 执行insertText方法插入某些文本。
            editor.insertText("and")
          }
        }}
      />
    </Slate>
  )
}

添加完成后,试着输入 & ,你会发现它突然变成了插入 and

这个示例展示了 Slate 的事件处理程序可以做到什么。editor 可以让你运行命令去执行所有的 event 对象。就是这么简单!