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


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

    1. import React, { useState, useEffect, useRef } from 'react';
    2. import './App.css';
    3. const App = () => {
    4. const [text, setText] = useState('');
    5. const textareaRef = useRef(null);
    6. useEffect(() => {
    7. const textarea = textareaRef.current;
    8. // 重置高度,防止高度累积
    9. textarea.style.height = 'auto';
    10. // 设置高度为内容的高度
    11. textarea.style.height = `${textarea.scrollHeight}px`;
    12. }, [text]);
    13. const handleChange = (event) => {
    14. setText(event.target.value);
    15. };
    16. return (
    17. <div className="container">
    18. <textarea
    19. id="dynamic-textarea"
    20. ref={textareaRef}
    21. value={text}
    22. onChange={handleChange}
    23. placeholder="请输入文字..."
    24. />
    25. <div className="display-text">{text}div>
    26. div>
    27. );
    28. };
    29. export default App;
    1. .container {
    2. width: 300px;
    3. margin: 50px auto;
    4. }
    5. #dynamic-textarea {
    6. width: 100%;
    7. min-height: 50px;
    8. max-height: 150px; /* 设置最大高度 */
    9. overflow-y: auto; /* 当内容超过最大高度时显示滚动条 */
    10. padding: 10px;
    11. box-sizing: border-box;
    12. font-size: 16px;
    13. line-height: 1.5;
    14. resize: none; /* 禁止用户手动调整大小 */
    15. border: 1px solid #ccc;
    16. border-radius: 4px;
    17. }
    18. .display-text {
    19. white-space: pre-wrap; /* 保留空格和换行符 */
    20. padding: 10px;
    21. margin-top: 20px;
    22. border: 1px solid #ccc;
    23. border-radius: 4px;
    24. background-color: #f9f9f9;
    25. font-size: 16px;
    26. line-height: 1.5;
    27. }
    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)。
  • 相关阅读:
    LeetCode 每日一题 2023/10/23-2023/10/29
    基于Python实现的GN算法
    Git 操作流程与命令汇总
    Java字符串String
    MYSQL语句
    (续)SSM整合之springmvc笔记(域对象共享数据)(P136-138)
    合肥中科深谷嵌入式项目实战——基于ARM语音识别的智能家居系统(一)
    C++17静态数据成员声明为inline
    JAVA面向对象基础
    bandit agent下棋AI(python编写) 通过强化学习RL 使用numpy
  • 原文地址:https://blog.csdn.net/m0_49471668/article/details/140023113