JavaScript训练合集——如何交换两个变量的值

170 篇文章 3 订阅

在我们的开发中, 经常遇到需要交换两个变量的值的需求, 实现的方法有非常多, 你了解的越多, 说明你对JavaScript越熟悉

临时变量法

这个方法再简单不过了, 就是创建一个临时变量作为中介, 实现变量值的交换

var a = 3,
    b = 4,
    c = undefined;
c = b;
b = a;
a = c;

这种方法虽然很简单, 但是并不是很好的实现方式, 很不推荐, 因为我们多声明了一个变量

加减法

var a = 3,
    b = 4;
a = a + b;
b = a - b;
a = a - b;

这种只通过加减法实现的方式比较巧妙

数组法

var a = 3,
    b = 4;
a = [a, b];
b = a[0];
a = a[1];

对象法

var a = 3,
    b = 4;
a = { a: b, b: a };
b = a.b;
a = a.a;

数组运算法

var a = 3,
    b = 4;
a = [b, b = a][0];

这种方法的实现比较独特, 数组内是可以进行运算操作的, 根据优先级, 首先会执行 b = a, 然后通过索引, b又会赋值给a;

按位异或法

var a = 3,
    b = 4;
a = a ^ b;
b = b ^ a;
a = a ^ b;

这种方法是比较偏向于底层的运算, 主要是把ab的值转换为二进制来做异或操作, 比如3的二进制是0011, 4的二进制是0100, 异或之后的结果是0111。然后的逻辑就和加法运算差不多了

解构赋值法

ES6有一个非常好用的解构赋值, 也可以很巧妙的运用到变量交换中.

var a = 3,
    b = 4;
[a, b] = [b, a];

这里强调一下, 以上方法并不适用于引用类型的变量, 只适用于基本类型

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CreatorRay

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值