我有两个变量:
var a = 1,
b = 2;
我的问题是如何交换它们?只有这个变量,没有任何对象。
我有两个变量:
var a = 1,
b = 2;
我的问题是如何交换它们?只有这个变量,没有任何对象。
当前回答
我们可以使用IIFE交换两个值,而不需要额外的参数
Var a = 5, b =8; B =(函数(a){ 返回一个 } (a, a = b)); 文档。写("a: "+ a+ " b: "+ b);
其他回答
直到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 = (function(){ a=b; return arguments[0]; })(a);
小提琴:http://jsfiddle.net/cherniv/4q226/
因为我听说这个方法运行得比较慢:
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'}
下面是交换两个变量值的一行代码。 给定变量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 >
现在你终于可以做到:
设a = 5; 令b = 10; [a, b] = [b, a];/ / ES6 console.log (a, b);