在两个JavaScript对象之间创建diff补丁的最有效方法是什么?

时间:2017-07-06 13:48:13

标签: javascript object jsperf

我正在尝试在javascript中的两个对象之间创建一个“补丁”,以便只在一个变量中更新数据。

var patch = {};

var o = {
  id: 'p1',
  kind: 'product',
  title: 'ProductTitle',
  price: 100,
  stock: 10,
};

var n = {
  title: 'ProductTitleRenamed',
  price: 100,
  stock: 20,
};

var patchExpected = {
  title: 'ProductTitleRenamed',
  stock: 20,
};

我在jsperf上使用vanilla / lodash方法尝试了多个场景,我不明白为什么最后一个比其他场景慢(我猜它与字符串访问有关)。原始版本在逻辑上更快(有很多if),但它真的很冗长,你知道其他优雅和高性能的解决方案(使用immutablejs,es6 map等)吗?

在Chrome 58.0.3029 / Mac OS X 10.12.4中进行测试

1 - 在新对象属性上使用lodash循环(3,006,759 ops / s)

_.forEach(n, (value, key) => {
  if (value !== o[key]) {
    patch[key] = value;
  }
});

2 - 有很多if(17,873,849 ops / s)

if (!_.isUndefined(n.id) && o.id !== n.id) {
  patch.id = n.id;
}

if (!_.isUndefined(n.kind) && o.kind !== n.kind) {
  patch.kind = n.kind;
}

if (!_.isUndefined(n.title) && o.title !== n.title) {
  patch.title = n.title;
}

if (!_.isUndefined(n.price) && o.price !== n.price) {
  patch.price = n.price;
}

if (!_.isUndefined(n.stock) && o.stock !== n.stock) {
  patch.stock = n.stock;
}

3 - 有很多如果使用util函数“isChanged”(15,146,180 ops / s)

function isChanged(n, o) {
  return !_.isUndefined(n) && o !== n;
}

if (isChanged(n.id, o.id)) {
  patch.id = n.id;
}

if (isChanged(n.kind, o.kind)) {
  patch.kind = n.kind;
}

if (isChanged(n.title, o.title)) {
  patch.title = n.title;
}

if (isChanged(n.price, o.price)) {
  patch.price = n.price;
}

if (isChanged(n.stock, o.stock)) {
  patch.stock = n.stock;
}

4 - 使用一个差异函数(更简洁)(4,360,005 ops / s)

function diff(field) {
  if (!_.isUndefined(n[field]) && o[field] !== n[field]) {
    patch[field] = n[field];
  }
}

diff('id');
diff('kind');
diff('title');
diff('price');
diff('stock');

https://jsperf.com/diff-patch

0 个答案:

没有答案