是不是可以逐个字符执行正则表达式?

huangapple go评论68阅读模式
英文:

Is it possible to exec regex one character at once?

问题

我想使用正则表达式作为状态机,每次只处理一个字符。

示例:

  1. // this matches only 13 or 123
  2. const createStateMachine = () => {
  3. const machine = {
  4. "": {
  5. 1: "1",
  6. },
  7. 1: {
  8. 2: "2",
  9. 3: "3",
  10. },
  11. 2: {
  12. 3: "3",
  13. },
  14. };
  15. let state = "";
  16. return (value) => {
  17. const nextState = machine[state][value];
  18. if (nextState) {
  19. state = nextState;
  20. return true;
  21. }
  22. return false;
  23. };
  24. };
  25. const exec = createStateMachine();
  26. document.querySelector("input").addEventListener("keydown", (event) => {
  27. if (!exec(event.key)) {
  28. event.preventDefault();
  29. }
  30. });

这个输入只允许输入13和123:

  1. <input>

以下是正则表达式版本,但显然不起作用:

  1. const regex = /^12?3$/;
  2. document.querySelector("input").addEventListener("keydown", (event) => {
  3. if (!regex.exec(event.key)) {
  4. event.preventDefault();
  5. }
  6. });

是否可以使用内置的正则表达式对象来实现这个目标?

英文:

I want to use regex like a state machine, feeding only one character at a time.

Example:

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

  1. // this matches only 13 or 123
  2. const createStateMachine = () =&gt; {
  3. const machine = {
  4. &quot;&quot;: {
  5. 1: &quot;1&quot;,
  6. },
  7. 1: {
  8. 2: &quot;2&quot;,
  9. 3: &quot;3&quot;,
  10. },
  11. 2: {
  12. 3: &quot;3&quot;,
  13. },
  14. };
  15. let state = &quot;&quot;;
  16. return (value) =&gt; {
  17. const nextState = machine[state][value];
  18. if (nextState) {
  19. state = nextState;
  20. return true;
  21. }
  22. return false;
  23. };
  24. };
  25. const exec = createStateMachine();
  26. document.querySelector(&quot;input&quot;).addEventListener(&quot;keydown&quot;, (event) =&gt; {
  27. if (!exec(event.key)) {
  28. event.preventDefault();
  29. }
  30. });

<!-- language: lang-html -->

  1. This input allows only 13 and 123
  2. &lt;input&gt;

<!-- end snippet -->

And here is the regex version but it obviously doesn't work:

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

  1. const regex = /^12?3$/
  2. document.querySelector(&quot;input&quot;).addEventListener(&quot;keydown&quot;, (event) =&gt; {
  3. if (!regex.exec(event.key)) {
  4. event.preventDefault();
  5. }
  6. });

<!-- language: lang-html -->

  1. &lt;input&gt;

<!-- end snippet -->

It is possible to use the built-in regex object for that?

答案1

得分: 2

可以使用内置的正则表达式对象吗?

不可以。

您可以解析正则表达式并从中构建自己的状态机,或者编写(或生成)一个匹配正则语言任何前缀的正则表达式,但是这两者都没有内置方法。

英文:

> It is possible to use the built-in regex object for that?

No.

You can either parse the regular expression and build your own state machine from that, or you write (or generate) a regular expression that matches any prefix of the regular language, but there exist no builtin methods for either of this.

huangapple
  • 本文由 发表于 2023年5月29日 21:40:23
  • 转载请务必保留本文链接:https://go.coder-hub.com/76357877.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定