React 腾讯面试手写题

题目如下:

用 React 和 JS 实现一个组件,组件分为左右两块

左侧模块:展示可选列表,如 [1,2,3,4,5],每一项是一个 checkbox,可以勾选和取消

勾选时,右侧模块会展示已选项的列表,并且每项旁边有个删除按钮,点击删除后,左侧对应项也会取消勾选


思路

这个题核心就是双向数据绑定,题中只有一个要管理的状态------右栏列表 selectedItems

点击左栏某一项 item 的勾选框,判断右栏中是否存在 item,若存在,则右栏移除 item;反之则添加 item。然后修改左栏的勾选状态 checked

右栏点击删除按钮时,使用列表的 filter 方法更新列表


代码

App.jsx

javascript 复制代码
import { useState } from "react";
import reactLogo from "./assets/react.svg";
import viteLogo from "/vite.svg";
import "./App.css";

function App() {
  const [options] = useState([1, 2, 3, 4, 5]);
  const [selectedItems, setSelectedItems] = useState([]);

  function changeCheckbox(item) {
    if (selectedItems.includes(item)) {
      setSelectedItems(selectedItems.filter((id) => id !== item));
    } else {
      setSelectedItems([...selectedItems, item]);
    }
  }

  function deleteItem(id) {
    setSelectedItems(selectedItems.filter((item) => item !== id));
  }

  return (
    <>
      <div className="container">
        <div className="left">
          {options.map((item) => {
            return (
              <div className="checkbox-item">
                {item}
                <input type="checkbox"
                 className="check"
                 checked={selectedItems.includes(item)}
                 onChange={() => changeCheckbox(item)} />
              </div>
            );
          })}
        </div>

        <div className="right">
          {selectedItems.map((item) => {
            return (
              <div className="selected-item">
                <span>{item} </span>
                <button 
                  className="delete-btn"
                  onClick={()=>deleteItem(item)}>删除</button>
              </div>
            );
          })}
        </div>
      </div>
    </>
  );
}

export default App;

App.css

css 复制代码
#root {
  max-width: 1280px;
  margin: 0 auto;
  padding: 2rem;
}

.container {
  display: flex;
}

.left, .right {
  border: 1px solid #ddd;
  border-radius: 8px;
  width: 200px;
}
.delete-btn {
  background-color: orange;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 0.25rem 0.5rem;
  cursor: pointer;
  font-size: 0.8rem;
}
相关推荐
soso196819 分钟前
JavaScript性能调优实战案例
javascript
Moment1 小时前
前端工程化 + AI 赋能,从需求到运维一条龙怎么搭 ❓❓❓
前端·javascript·面试
Joker Zxc1 小时前
【前端基础(Javascript部分)】6、用JavaScript的递归函数和for循环,计算斐波那契数列的第 n 项值
开发语言·前端·javascript
Highcharts.js1 小时前
React 图表如何实现下钻(Drilldown)效果
开发语言·前端·javascript·react.js·前端框架·数据可视化·highcharts
chushiyunen2 小时前
python中的魔术方法(双下划线)
前端·javascript·python
终端鹿2 小时前
Vue2 迁移 Vue3 避坑指南
前端·javascript·vue.js
进击的尘埃2 小时前
Signals 跨框架收敛:TC39 提案、Solid、Angular、Preact 的实现差异与调度策略对比
javascript
进击的尘埃3 小时前
从多仓到 Monorepo 的渐进式迁移:Git 历史保留、依赖收敛与缓存调优
javascript
SuperEugene3 小时前
TypeScript+Vue 实战:告别 any 滥用,统一接口 / Props / 表单类型,实现类型安全|编码语法规范篇
开发语言·前端·javascript·vue.js·安全·typescript
gis开发4 小时前
cesium 中添加鹰眼效果
前端·javascript