我有两个变量:

var a = 1,
    b = 2;

我的问题是如何交换它们?只有这个变量,没有任何对象。


你可以这样做:

var a = 1,
    b = 2,
    tmp;
tmp = a;
a = b;
b = tmp;

对于可读性和可维护性,这是无可比拟的(至少在JavaScript中)。任何维护代码的人(包括六个月后的您)都将确切地知道发生了什么。

由于这些都是整数,您还可以使用任意数量的聪明技巧进行交换,而不需要使用第三个变量。例如,你可以使用按位的xor操作符:

设a = 1, b = 2; A = A ^ b; B = a ^ B; A = A ^ b; Console.log ('a现在是:',a); Console.log ('b现在是:',b);

这叫做异或交换算法。维基百科的这篇文章描述了它的运作理论。

“有能力的程序员清楚地意识到自己脑袋的大小是有限的。因此,他以完全谦卑的态度对待他的任务,并避免像瘟疫一样的聪明伎俩。”——埃德斯格·迪克斯特拉


您可以使用临时交换变量或XOR。

a = a ^ b
b = a ^ b
a = a ^ b

这只是一个基本的逻辑概念,适用于支持异或操作的每种语言。

编辑:见注释。忘了说,这只适用于整数。假设问题线程中的整数变量


使用第三个变量,像这样:

var a = 1,
    b = 2,
    c = a;

a = b; // must be first or a and b end up being both 1
b = c;

DEMO -使用第三个变量



下面是交换两个变量值的一行代码。 给定变量a和b:

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

演示如下:

var = 1, b = 2, 输出= . getelementbyid(“输出”); 输出。innerHTML="<p>原来:"+a+", "+b+"</p>"; //交换变量a和b的值 B = [a, a = B][0]; 输出。innerHTML+="<p>交换:"+a+", "+b+"</p>"; < div id = "输出" > < / div >


正如你的问题是宝贵的“只有这个变量,没有任何对象。,答案也会弥足珍贵:

Var a = 1, B = 2

a=a+b;
b=a-b;
a=a-b;

这是个诡计 正如罗德里戈·阿西斯所说,它“可以更短”

 b=a+(a=b)-b;

演示: http://jsfiddle.net/abdennour/2jJQ2/


我们怎么会错过这些经典的俏皮话呢

var a = 1, b = 2
a = ({a:b, _:(b=a)}).a;

And

var a = 1, b = 2
a = (_=b,b=a,_);

最后一个暴露了全局变量“_”,但这并不重要,因为典型的javascript惯例是使用它作为“不在乎”变量。


下面是一行代码,假设a和b已经存在,并且需要交换值:

var c=a, a=b, b=c;

正如@Kay所提到的,这实际上比数组方式执行得更好(几乎是数组方式的2倍)。


我在这里看到了编程奥林匹克。还有一个更棘手的单行解决方案:

b = (function(){ a=b; return arguments[0]; })(a);

小提琴:http://jsfiddle.net/cherniv/4q226/


不要使用下面的代码。这不是交换两个变量值的推荐方法(简单地使用临时变量)。它只是展示了一个JavaScript技巧。

这个解决方案不使用临时变量,不使用数组,只添加一次,而且速度很快。 事实上,在一些平台上,它有时比临时变量更快。 它适用于所有数字,从不溢出,并处理边界情况,如无穷大和NaN。

a = b + (b=a, 0)

它分两步工作:

(b=a, 0)将b设置为a的旧值并产生0 A = b + 0将A设置为b的旧值


单行交换

a = a^b^(b^=(a^b));

ES6 (Firefox和Chrome已经支持它 数组匹配)):

设a = 5, b = 6; [a, b] = [b, a]; console.log(“${一}$ {b}”);


我们可以这样交换var:

var val1 =  117,
    val2 = 327;

val2 = val1-val2; 
console.log(val2);
val1 = val1-val2;
console.log(val1);
val2 = val1+val2;
console.log(val2);

var a = 5;
var b = 10;

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

//or
b = [a, b];
a = b[1];
b = b[0];


alert("a=" + a + ',' + "b=" + b);

删除或注释2 //or并使用一组代码运行

http://jsfiddle.net/USdv8/57/


从ES6开始,你还可以更优雅地交换变量:

var a = 1,
    b = 2;

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

console.log('a:', a, 'b:', b); // a: 2 b: 1

现在你终于可以做到:

设a = 5; 令b = 10; [a, b] = [b, a];/ / ES6 console.log (a, b);


let a = 2, b = 4;
[b, a] = [a, b];

更详细的方法是

let a = 2, b = 4;
a = [a, b];
b = a[0];
a = a[1];

ES6解构:

使用数组:[a, b] = [b, a];//我的最爱

使用对象:{a, b} = {a:b, b:a};//也不错


直到ES5,为了交换两个数字,你必须创建一个临时变量,然后交换它。 但是在ES6中,使用数组解构很容易交换两个数字。看到的例子。

let x,y;
[x,y]=[2,3];
console.log(x,y);      // return 2,3

[x,y]=[y,x];
console.log(x,y);      // return 3,2

了解更多关于JavaScript ES6解构的知识


因为我听说这个方法运行得比较慢:

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

如果你计划将你的变量存储在一个对象(或数组)中,这个函数应该工作:

function swapVars(obj, var1, var2){
    let temp = obj[var1];
    obj[var1] = obj[var2];
    obj[var2] = temp;
}

用法:

let test = {a: 'test 1', b: 'test 2'};

console.log(test); //output: {a: 'test 1', b: 'test 2'}

swapVars(test, 'a', 'b');

console.log(test); //output: {a: 'test 2', b: 'test 1'}

我们可以使用IIFE交换两个值,而不需要额外的参数

Var a = 5, b =8; B =(函数(a){ 返回一个 } (a, a = b)); 文档。写("a: "+ a+ " b: "+ b);


虽然前面给出了同样的答案,但这里有一个png来描述它。

最简单的形式:


第一个方法, Var a = 5, b = 9; A = A - b; B = a + B; A = b - A; console.log (a, b);

第二种方式

Var a = 19, b = 22; [a, b] = [b, a]; console.log (a, b);

简单明了的答案。