我有两个变量:
var a = 1,
b = 2;
我的问题是如何交换它们?只有这个变量,没有任何对象。
我有两个变量:
var a = 1,
b = 2;
我的问题是如何交换它们?只有这个变量,没有任何对象。
当前回答
不要使用下面的代码。这不是交换两个变量值的推荐方法(简单地使用临时变量)。它只是展示了一个JavaScript技巧。
这个解决方案不使用临时变量,不使用数组,只添加一次,而且速度很快。 事实上,在一些平台上,它有时比临时变量更快。 它适用于所有数字,从不溢出,并处理边界情况,如无穷大和NaN。
a = b + (b=a, 0)
它分两步工作:
(b=a, 0)将b设置为a的旧值并产生0 A = b + 0将A设置为b的旧值
其他回答
我在这里看到了编程奥林匹克。还有一个更棘手的单行解决方案:
b = (function(){ a=b; return arguments[0]; })(a);
小提琴:http://jsfiddle.net/cherniv/4q226/
我们怎么会错过这些经典的俏皮话呢
var a = 1, b = 2
a = ({a:b, _:(b=a)}).a;
And
var a = 1, b = 2
a = (_=b,b=a,_);
最后一个暴露了全局变量“_”,但这并不重要,因为典型的javascript惯例是使用它作为“不在乎”变量。
现在你终于可以做到:
设a = 5; 令b = 10; [a, b] = [b, a];/ / ES6 console.log (a, b);
下面是交换两个变量值的一行代码。 给定变量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 >
直到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解构的知识