es6常见数组、对象中的整合与拆解

一、对象整合优化方案

1. 合并对象(Object.assign/ 展开语法)

场景 :合并多个配置项、表单数据更新。
方案 :使用 Object.assign 或展开语法(...)。
示例

javascript

ini 复制代码
// 合并配置项
const defaultConfig = { theme: 'light', fontSize: 14 };
const userConfig = { fontSize: 16, showSidebar: true };
const finalConfig = { ...defaultConfig, ...userConfig };
// 结果: { theme: 'light', fontSize: 16, showSidebar: true }

项目应用

在 React 项目中,合并 props 和默认值:

javascript

ini 复制代码
const MyComponent = (props) => {
  const { name = '默认值', age } = props;
  // 等价于: const defaults = { name: '默认值' };
  // const { name, age } = { ...defaults, ...props };
};

2. 深度合并对象

场景 :嵌套对象的合并(如复杂配置、状态管理)。
方案 :使用 lodash.merge 或自定义递归函数。
示例

javascript

css 复制代码
import merge from 'lodash/merge';

const obj1 = { a: { b: 1 } };
const obj2 = { a: { c: 2 } };
const merged = merge(obj1, obj2);
// 结果: { a: { b: 1, c: 2 } }

项目应用

在 Vuex/Pinia 中合并状态:

javascript

ini 复制代码
const state = {
  user: {
    info: { name: '张三', age: 20 },
    settings: { theme: 'light' }
  }
};

// 更新user.info,保留其他字段
const newUserInfo = { age: 21, gender: '男' };
state.user.info = merge(state.user.info, newUserInfo);

3. 对象属性过滤 / 转换

场景 :接口数据清洗(如移除空值、重命名字段)。
方案 :使用 Object.fromEntries + Object.entries
示例

javascript

javascript 复制代码
// 过滤空值
const data = { name: '张三', age: null, email: '' };
const filteredData = Object.fromEntries(
  Object.entries(data).filter(([key, value]) => value !== null && value !== '')
);
// 结果: { name: '张三' }

项目应用

在表单提交前过滤无效数据:

javascript

ini 复制代码
const formData = { username: 'test', password: '', remember: false };
const validData = Object.fromEntries(
  Object.entries(formData).filter(([_, value]) => value !== '')
);

二、数组整合优化方案

1. 数组合并与去重

场景 :合并分页数据、合并标签列表。
方案 :使用 SetArray.reduce
示例

javascript

ini 复制代码
// 合并并去重
const arr1 = [1, 2, 3];
const arr2 = [3, 4, 5];
const merged = [...new Set([...arr1, ...arr2])];
// 结果: [1, 2, 3, 4, 5]

项目应用

在无限滚动加载中合并数据:

javascript

ini 复制代码
const [list, setList] = useState([]);

// 加载更多
const loadMore = (newData) => {
  setList([...new Set([...list, ...newData])]);
};

2. 数组对象合并(按 ID)

场景 :更新列表中的部分数据(如评论列表更新某条评论)。
方案 :使用 MapArray.find
示例

javascript

ini 复制代码
const list = [
  { id: 1, name: 'A' },
  { id: 2, name: 'B' }
];
const updatedItem = { id: 2, name: 'B(已更新)' };

const newList = list.map(item => 
  item.id === updatedItem.id ? updatedItem : item
);

项目应用

在 React 中更新列表项:

javascript

ini 复制代码
const updateComment = (commentId, newContent) => {
  setComments(prev => prev.map(item => 
    item.id === commentId ? { ...item, content: newContent } : item
  ));
};

3. 数组分组与聚合

场景 :按类别分组商品、统计数据。
方案 :使用 Array.reduce
示例

javascript

ini 复制代码
const products = [
  { id: 1, category: '水果', name: '苹果' },
  { id: 2, category: '蔬菜', name: '胡萝卜' },
  { id: 3, category: '水果', name: '香蕉' }
];

const grouped = products.reduce((acc, item) => {
  (acc[item.category] = acc[item.category] || []).push(item);
  return acc;
}, {});
// 结果: { 水果: [{...}, {...}], 蔬菜: [{...}] }

项目应用

在电商项目中按分类展示商品:

javascript

javascript 复制代码
const renderProductsByCategory = () => {
  const groupedProducts = products.reduce((acc, p) => {
    (acc[p.category] = acc[p.category] || []).push(p);
    return acc;
  }, {});

  return Object.entries(groupedProducts).map(([category, items]) => (
    <div key={category}>
      <h3>{category}</h3>
      <ul>
        {items.map(item => <li key={item.id}>{item.name}</li>)}
      </ul>
    </div>
  ));
};

三、实战技巧

1. 链式操作简化逻辑

场景 :复杂数据处理(如筛选、转换、分组)。
示例

javascript

ini 复制代码
const data = [
  { id: 1, name: 'A', score: 85 },
  { id: 2, name: 'B', score: 92 },
  { id: 3, name: 'C', score: 78 }
];

// 筛选高分,提取名字,转大写
const highScores = data
  .filter(item => item.score >= 80)
  .map(item => item.name.toUpperCase());
// 结果: ['A', 'B']

2. 使用工具库提升效率

  • Lodash :提供 mergegroupBykeyBy 等工具函数。

    javascript

    ini 复制代码
    import { groupBy, keyBy } from 'lodash';
    
    const users = [
      { id: 1, role: 'admin' },
      { id: 2, role: 'user' },
      { id: 3, role: 'user' }
    ];
    
    const usersByRole = groupBy(users, 'role');
    // 结果: { admin: [{...}], user: [{...}, {...}] }
  • Ramda:函数式编程工具库,支持管道操作。

    javascript

    ini 复制代码
    import { pipe, filter, map, toUpper } from 'ramda';
    
    const processData = pipe(
      filter(item => item.score >= 80),
      map(item => item.name),
      map(toUpper)
    );
    
    const result = processData(data);

3. 在状态管理中应用

场景 :Redux/MobX 更新嵌套状态。
示例

javascript

go 复制代码
// Redux reducer 中不可变更新
const initialState = {
  users: [
    { id: 1, name: '张三' },
    { id: 2, name: '李四' }
  ]
};

const reducer = (state, action) => {
  switch (action.type) {
    case 'UPDATE_USER':
      return {
        ...state,
        users: state.users.map(user => 
          user.id === action.payload.id 
            ? { ...user, ...action.payload } 
            : user
        )
      };
    default:
      return state;
  }
};
相关推荐
Live0000032 分钟前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉33 分钟前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
兆子龙43 分钟前
从高阶函数到 Hooks:React 如何减轻开发者的心智负担(含 Demo + ahooks 推荐)
前端
狗胜1 小时前
测试文章 - API抓取
前端
三小河1 小时前
VS Code 集成 claude-code 教程:告别海外限制,无缝对接国内大模型
前端·程序员
jerrywus1 小时前
前端老哥的救命稻草:用 Obsidian 搞定 Claude Code 的「金鱼记忆」
前端·agent·claude
球球pick小樱花1 小时前
游戏官网前端工具库:海内外案例解析
前端·javascript·css
用户60572374873081 小时前
AI 编码助手的规范驱动开发 - OpenSpec 初探
前端·后端·程序员
狗胜1 小时前
AI观察日记 2026-03-02|CLAUDE、TYPE、APPFUNCTIONS:掘金热门里的下一步信号
前端