reactjs - Html 在 Redux 表单字段上放置固定文本
问题描述
如何在用户无法删除的 Redux 表单字段中放置默认文本(输入开始时的固定文本)。
我想要的第二件事是光标将在此固定文本之后被索引。
对于不使用 redux:Html 将固定文本放在输入文本上
解决方案
您可以防止更改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>
);
};
推荐阅读
- swift - 通过以下错误引用类内部的协议:Expected member name or constructor call after type name
- php - 表单提交未在 Ajax 成功页面上执行
- java - Spring JPA如何从任意数据结构中检索数据
- multithreading - go 进程产生的 OS 线程数会不会减少?
- python - 在使用 mongodb 和 django 时我应该使用 mongoengine.Document 还是 models.Model
- pandas - 网页抓取 JOINURL 存根和抓取的页面 href
- google-cloud-datastore - 自适应地构建对象化过滤器
- javascript - 访问 WebView 中的 DOM 元素
- c - 如何在不重新创建窗口的情况下更改窗口的 X 和 Y 坐标
- git - 如何修复 git pull 失败“致命:索引包失败”