我有两个变量:
var a = 1,
b = 2;
我的问题是如何交换它们?只有这个变量,没有任何对象。
我有两个变量:
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的旧值
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
let a = 2, b = 4;
[b, a] = [a, b];
更详细的方法是
let a = 2, b = 4;
a = [a, b];
b = a[0];
a = a[1];
直到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);
第一个方法, 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);
简单明了的答案。