V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
az22c
V2EX  ›  JavaScript

不同对象,对象行为相同但对象属性的命名不同,怎么封装“兼容处理这些对象的模块”?

  •  
  •   az22c · 2022-08-01 15:26:11 +08:00 · 1406 次点击
    这是一个创建于 898 天前的主题,其中的信息可能已经有所发展或是发生改变。

    obj1 和 obj2 等等对象,都是历史遗留,对象里面属性名都是固定死的。对象属性名不同但是属性的用法都是一样的。

    目前想封装一个 myNewModule 模块(先认为是函数,不一定是函数)能处理它们,但是能不能不用 options 参数来告知属性名,想改为一种在未来 debug 时更加容易理解的方式来告知 /注册。

    const obj1 = {
      registerLabel: '张三',
      registerAge: 56,
      buyerCartList: []
      // ...还有十几个需要传入 myNewModule  模块的属性
    }
    
    const obj2 = {
      userLabel: '李四',
      userAge: 56,
      userCartList: []
      // ...还有十几个需要传入 myNewModule 模块的属性
    }
    
    
    myNewModule(obj1, {
      labelName: 'registerLabel',
      ageName: 'registerAge',
      cartListName: 'buyerCartList'
    })
    myNewModule(obj2, {
      labelName: 'userLabel',
      ageName: 'userAge',
      cartListName: 'userCartList'
    })
    
    // 模块开发中:
    const myNewModule = (target, options) => {
      const label = target[options.labelName]
      const age = target[options.ageName]
      const cartList = target[options.cartListName]
      // ...处理 label age 等十多个属性
    }
    
    3 条回复    2022-08-01 15:38:51 +08:00
    sun2920989
        1
    sun2920989  
       2022-08-01 15:31:20 +08:00   ❤️ 1
    要么外部处理 要么内部处理 脏活总要有人做
    az22c
        2
    az22c  
    OP
       2022-08-01 15:35:39 +08:00
    function getObject (target) {
    if (target === obj1) {
    return {
    label: obj1.registerLabel,
    age: obj1.registerAge,
    cartList: obj1.buyerCartList,
    }
    } else if (target === obj2) {
    return {
    label: obj2.userLabel,
    age: obj2.userAge,
    cartList: obj2.userCartList,
    }
    }
    }
    az22c
        3
    az22c  
    OP
       2022-08-01 15:38:51 +08:00
    打算在 myNewModule 里面,调用一次 getObject ,不论传入的是 obj1 还是 obj2 ,getObject 获取统一了属性名称的对象
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1004 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 20:15 · PVG 04:15 · LAX 12:15 · JFK 15:15
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.