【问题标题】:Html Put a fixed text on an Redux Form FieldHtml 在 Redux 表单字段上放置固定文本
【发布时间】:2021-08-01 15:53:05
【问题描述】:

如何在 Redux 表单字段中放置用户无法删除的默认文本(输入开始时的固定文本)。

我想要的第二件事是光标将在此固定文本之后被索引。

不使用 redux:Html Put a fixed text on an input text

【问题讨论】:

  • 这个问题似乎与 Redux 无关。请重新考虑您的标签
  • @MichaelRovinsky 对于 redux 表单

标签: reactjs redux react-redux redux-form


【解决方案1】:

您可以防止在onChange 回调中更改输入值前缀:

const {useState} = React;

const Component = ({defaultText}) => {
    const [text, setText] = useState(defaultText);
    const onChangeText = (e) => {
      if (e.target.value.substr(0, defaultText.length) === defaultText)
        setText(e.target.value);
    }  
   
    return (
      <div>
        <input onChange={onChangeText} value={text} />
      </div>
    )
}

ReactDOM.render(<Component defaultText='ABC'/>, document.querySelector("#app"))
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#app {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  transition: all 0.2s;
}

input {
  margin-right: 5px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/17.0.1/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/17.0.1/umd/react-dom.production.min.js"></script>
<div id="app"></div>

UPD:对于Redux Form Field 使用:

import React, {useState} from "react";
import { Field } from "redux-form";

const defaultText = "ABC";

const TextWithPrefix = () => {
  const [text, setText] = useState(defaultText);
  const onChangeText = (e) => {
    if (e.target.value.substr(0, defaultText.length) === defaultText)
      setText(e.target.value);
  };

  return (<input onChange={onChangeText} value={text} />);
};

const FormComponent = ({ handleSubmit, onSubmit }) => {
  return (
    <div>
      <form onSubmit={handleSubmit(onSubmit)}>
        <Field component={TextWithPrefix} />
      </form>
    </div>
  );
};

【讨论】:

猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-07-06
  • 2022-12-29
  • 2022-07-16
  • 1970-01-01
  • 1970-01-01
  • 2017-12-26
  • 2013-04-20
相关资源
最近更新 更多