微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用Angular材质从Mat形式的字段计算数学方程,该Mat字段的公式类似于具有等号的Excel

如何解决如何使用Angular材质从Mat形式的字段计算数学方程,该Mat字段的公式类似于具有等号的Excel

我是Angular的新手。我想在Mat表单字段内键入= 100 + 5或= 8 * 5/2,当我按Enter键时,它会在Mat表单字段本身内计算并显示结果。我不确定如何在MatFormField中处理这些方程式。请帮忙

预先感谢!

解决方法

正如@MoxxiManagarm所说,MatFormField只是包装输入的东西,然后可以是文本,文本区域,选择...,因此在您的情况下,您正在谈论输入。因此,您可以轻松地将输入解决方案包括在MatFormField中。

通过简单的(keyup.enter)指令,您可以在用户使用Enter键时将输入绑定到方法上。

<input type="text" (keyup.enter)="onEnter($event)">

然后在您的方法上,确保要像Excel一样执行操作,请检查第一个字符是否相等。

onEnter(event){
  const value = event.target.value
  if (value[0] == "="){
    event.target.value = eval(value.substring(1)) // Here you get only the operation to evaluate it without the first "equal"
  }
}

Here是一次闪电战

,

MatFormField只是包装器组件。我想我们正在谈论一种输入。

您可以对输入事件做出反应,只需覆盖内容即可

<input (keydown.enter)="solveEquation($event)" />
  solveEquation($event) {
    const element = $event.target;
    element.value += `=${this.solve(element.value)}`
  }

  private solve(equation: string): number {
    // any logic to solve the string equation
    return 111;
  }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。