• JS数组转对象,JS对象转数组


    JS数组转对象

    1. // 原始数据
    2. const arr = [{ label: 'title_one', val: '参数值1' }, { label: 'title_two', val: '参数值2' }];
    3. // 转成以下格式:
    4. obj = { title_one: '参数值1', title_two: '参数值2' };

    方法

    1. /** 数组转对象
    2. * @param {Object} e 原始数组
    3. * @param {Object} key 键
    4. * @param {Object} val 值
    5. */
    6. arrTransferObj(e, key, val) {
    7. return e.reduce((obj, item) => {
    8. obj[item[key]] = item[val];
    9. return obj;
    10. }, {}); // 数组的reduce方法,使数组的obj初始值为{},将数组中每一个对象所需的值,分别作为对象中的键与值
    11. }

    简写

    1. /** 数组转对象
    2. * @param {Object} e 原始数组
    3. * @param {Object} key 键
    4. * @param {Object} val 值
    5. */
    6. arrTransferObj(e, key, val) {
    7. // 数组的reduce方法,使数组的obj初始值为{},将数组中每一个对象所需的值,分别作为对象中的键与值
    8. return e.reduce((obj, item) => ((obj[item[key]] = item[val]), obj), {});
    9. }

    使用方法

    1. const arr = [{ label: 'title_one', val: '参数值1' }, { label: 'title_two', val: '参数值2' }];
    2. console.log(this.arrTransferObj(arr, 'label', 'val'));

    JS对象转数组

    1. // 原始数据
    2. obj = { title_one: '参数值1', title_two: '参数值2' };
    3. // 转成以下格式:
    4. const arr = [{ label: 'title_one', val: '参数值1' }, { label: 'title_two', val: '参数值2' }];

    方法

    1. /** 对象转数组
    2. * @param {Object} e 原始数组
    3. * @param {Object} key 键
    4. * @param {Object} val 值
    5. */
    6. objTransferArr(e, key, val) {
    7. let result = [];
    8. for (let item in e) {
    9. result.push({
    10. [key]: item,
    11. [val]: e[item]
    12. });
    13. }
    14. return result;
    15. }

    使用方法

    1. const obj = { title_one: '参数值1', title_two: '参数值2' };
    2. console.log(this.objTransferArr(obj, 'label', 'val'));
  • 相关阅读:
    Vatee万腾平台:技术赋能,驱动产业升级新动力
    在Ubuntu18.04系统下搭建redis 一主(服务器)多从
    LabVIEW中如何实现任意形状的不规则按键
    ant-design版本升级从V4到V5
    JAVA 注解
    Day822.Happens-Before 规则 -Java 并发编程实战
    GCC Rust获批将被纳入主线代码库,或将于GCC 13中与大家见面
    操作系统-设备
    Java容器之迭代器和Collections
    adb调试Linux嵌入式设备记录
  • 原文地址:https://blog.csdn.net/AdminGuan/article/details/125507843