react输入框输入的空格 样式 和输入后页面显示一致

为了确保在 React 输入框中输入的空格样式和输入后页面显示一致,你可以使用 CSS 的 white-space 属性来控制空格的显示。具体来说,可以使用 pre-wrap 值来保留空格和换行符。

javascript 复制代码
import React, { useState, useEffect, useRef } from 'react';
import './App.css';

const App = () => {
  const [text, setText] = useState('');
  const textareaRef = useRef(null);

  useEffect(() => {
    const textarea = textareaRef.current;
    // 重置高度,防止高度累积
    textarea.style.height = 'auto';
    // 设置高度为内容的高度
    textarea.style.height = `${textarea.scrollHeight}px`;
  }, [text]);

  const handleChange = (event) => {
    setText(event.target.value);
  };

  return (
    <div className="container">
      <textarea
        id="dynamic-textarea"
        ref={textareaRef}
        value={text}
        onChange={handleChange}
        placeholder="请输入文字..."
      />
      <div className="display-text">{text}</div>
    </div>
  );
};

export default App;
css 复制代码
.container {
  width: 300px;
  margin: 50px auto;
}

#dynamic-textarea {
  width: 100%;
  min-height: 50px;
  max-height: 150px; /* 设置最大高度 */
  overflow-y: auto; /* 当内容超过最大高度时显示滚动条 */
  padding: 10px;
  box-sizing: border-box;
  font-size: 16px;
  line-height: 1.5;
  resize: none; /* 禁止用户手动调整大小 */
  border: 1px solid #ccc;
  border-radius: 4px;
}

.display-text {
  white-space: pre-wrap; /* 保留空格和换行符 */
  padding: 10px;
  margin-top: 20px;
  border: 1px solid #ccc;
  border-radius: 4px;
  background-color: #f9f9f9;
  font-size: 16px;
  line-height: 1.5;
}
  1. React 组件

    • 使用 useState 来管理输入框的内容。
    • 使用 useRef 来获取 textarea 的 DOM 节点。
    • 使用 useEffect 来监听 text 状态的变化,每次输入内容时动态调整输入框的高度。
    • handleChange 函数用于更新 text 状态。
  2. CSS 部分

    • #dynamic-textarea:设置输入框的最小高度(min-height)和最大高度(max-height)。当内容超过最大高度时,使用 overflow-y: auto 显示垂直滚动条。
    • resize: none:禁止用户手动调整输入框的大小。
    • white-space: pre-wrap:在 .display-text 类中使用 white-space: pre-wrap 来保留空格和换行符,使输入框中的内容和显示的内容样式一致。
  3. 动态调整高度

    • useEffect 中,每次 text 状态变化时,重置输入框的高度为 auto,然后将高度设置为内容的实际高度(scrollHeight)。
相关推荐
喵叔哟19 分钟前
重构代码之取消临时字段
java·前端·重构
青锐CC1 小时前
webman使用中间件验证指定的控制器及方法[青锐CC]
中间件·前端框架·php
还是大剑师兰特1 小时前
D3的竞品有哪些,D3的优势,D3和echarts的对比
前端·javascript·echarts
王解1 小时前
【深度解析】CSS工程化全攻略(1)
前端·css
一只小白菜~1 小时前
web浏览器环境下使用window.open()打开PDF文件不是预览,而是下载文件?
前端·javascript·pdf·windowopen预览pdf
方才coding1 小时前
1小时构建Vue3知识体系之vue的生命周期函数
前端·javascript·vue.js
阿征学IT1 小时前
vue过滤器初步使用
前端·javascript·vue.js
王哲晓1 小时前
第四十五章 Vue之Vuex模块化创建(module)
前端·javascript·vue.js
丶21361 小时前
【WEB】深入理解 CORS(跨域资源共享):原理、配置与常见问题
前端·架构·web
发现你走远了1 小时前
『VUE』25. 组件事件与v-model(详细图文注释)
前端·javascript·vue.js