在javascript中使用函数交换对象的两个属性

时间:2014-12-19 21:54:31

标签: javascript jquery function object

我正在尝试编写一个函数,它将接受两个对象,在这种情况下是人,并且只交换两个属性。这是我对人的功能:

function Person (tall, weight, gender, iq, favoriteColor) {
  this.tall = tall;
  this.weight = weight;
  this.gender = gender;
  this.iq = iq;
  this.favoriteColor = favoriteColor;
}

var joe = new Person("6-2", 180, "male", 130, "blue"); 
var bob = new Person("5-11", 150, "male", 120, "red");

所以我想交换JUST他们的IQs和favoriteColor。

到目前为止,我有:

function Swap(a, b) {
  var i = a;
  a = b;
  b = i;
  console.log(a, b);
}

这显然交换了所有属性,但我无法弄清楚如何只交换两个并仍然将它们作为对象登录。我试过了:

function Swap(a, b) {
  var a = a.iq + a.favoriteColor;
  var b = b.iq + b.favoriteColor;
  var i = a;
  a = b;
  b = i;
  console.log(a, b);
}

但这会在控制台中返回:

120red 130blue.

从技术上讲,它交换了两个值,但它们作为对象的结构已经消失,而它们应该保留的其他三个属性也消失了。如何编写交换函数来执行此操作?

谢谢!

4 个答案:

答案 0 :(得分:3)

这就是你想要的。您需要交换各个字段。你不能像你一样添加它们。此外,最好不要对已经声明的变量使用相同的名称,这太令人困惑了。

function Swap(a, b) {
  var i = a.iq;
  a.iq = b.iq;
  b.iq = i;

  i = a.favoriteColor;
  a.favoriteColor= b.favoriteColor;
  b.favoriteColor = i;
  console.log(a, b);
}

答案 1 :(得分:1)

function Swap(a, b) {
  var newBIq = a.iq
  var newBColor = a.favoriteColor;
  var newAIq = b.iq
  var newAColor = b.favoriteColor;
  a.iq = newAIq;
  a.favoriteColor = newAColor;
  b.iq = newBIq;
  b.favoriteColor = newBColor
  console.log(a, b);
}

在这里,您可以看到所需的4个值。我希望命名比i,j:D

更有助于理解

答案 2 :(得分:1)

如果我们采取this solution to swap values ...

b = [a, a = b][0];

......我们可以这样做......

function Swap(a, b) {
    b.iq = [a.iq, a.iq = b.iq][0];
    b.favoriteColor = [a.favoriteColor, a.favoriteColor = b.favoriteColor][0];
}

如果你可以使用ECMAScript 6,你甚至可以

function Swap(a, b) {
    [a.iq, b.iq] = [b.iq, a.iq]
    [a.favoriteColor, b.favoriteColor] = [b.favoriteColor, a.favoriteColor]
}

答案 3 :(得分:0)

这将交换对象a和b之间的键数组中键的所有值:

function Swap(a,b, keys){
    for(var i=0; i<keys.length; i++){
        var currentKey = keys[i];
        var temp = a[currentKey];
        a[currentKey] = b[currentKey];
        b[currentKey] = temp;
    }
}