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

news/2024/7/11 1:29:22 标签: javascript, 前端, es6

在我们的开发中, 经常遇到需要交换两个变量的值的需求, 实现的方法有非常多, 你了解的越多, 说明你对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];

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


http://www.niftyadmin.cn/n/1576368.html

相关文章

display none隐藏后如果表单有数值,那么他的数值还存在!

以前以为display:none后他的值就不存在了&#xff0c; display:none隐藏后如果表单有数值&#xff0c;那么他的数值还存在。(项目出了问题&#xff01;&#xff01;) <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR…

如何使用JS实现一个录屏功能

码字不易&#xff0c;有帮助的同学希望能关注一下我的微信公众号&#xff1a;Code程序人生&#xff0c;感谢&#xff01;代码自用自取。 带大家用JavaScript实现一个录屏功能。OBS studio很好用&#xff0c;但JavaScript也一样好用&#xff0c;现在&#xff0c;我们用JavaScrip…

Fluent动网格【2】:Profile文件

动网格中一个重要任务是部件运动方式的指定。在动网格中指定部件的运动&#xff0c;往往将部件的运动方式指定为其加速度、速度或位移与时间的相关关系&#xff0c;本文主要讲述如何在Fluent中利用瞬态Profile文件指定部件的运动方式。 在Fluent中指定部件运动主要有两种方式&a…

零基础入门微信小程序系列之——校园跑腿

前段时间在准备校招的事情&#xff0c;没有太多经历给大家分享博客和视频。最近校招已经尘埃落定&#xff0c;在策划一个零基础入门小程序的系列视频&#xff0c;在某站持续输出。 小程序的主要功能与微信目前线上的校园跑跑乐同步。 从0开始编写&#xff0c;一点一点的带着大…

微信支付-公众号支付

2019独角兽企业重金招聘Python工程师标准>>> 接口文档&#xff1a;https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter7_1 前期准备 1、设置支付目录 2、设置网页授权域名 统一下单接口 URL地址&#xff1a;https://api.mch.weixin.qq.com/pay/unifiedorde…

面试官:谈谈Vue实例挂载的过程

Vue2目前已经出现在大众视野中非常久了&#xff0c;甚至Vue3都已经开始投入使用&#xff0c;所有大家对于Vue2的掌握程度要逐步加深&#xff0c;即使你不想面大厂&#xff0c;也要到达源码级的。 Vue实例的挂载过程是一个面试中高频出现的考点&#xff0c;今天带着大家根据源码…

深度解析Promise的核心功能并手写实现

码字不易&#xff0c;有帮助的同学希望能关注一下我的微信公众号&#xff1a;Code程序人生&#xff0c;感谢&#xff01;代码自用自取。 Promise作为前端目前必不可少的内容&#xff0c;目前对于前端工程师的考察已经不满足于对于Promise的简单使用&#xff0c;中大公司的要求是…

JS手写实现call、apply、bind(超详细)

好久不更新了哦&#xff0c;最近又在找工作。复习一下JS中非常重要的一部分内容&#xff0c;关于this指向的问题 常规的this指向可以简单总结为谁引用就指向谁&#xff0c;找不到谁引用就指向window。 this指向中还有非常重要的一部分&#xff0c;就是改变this指向的方法。原生…