如何在 JavaScript 中交换两个变量?
我们将学习使用各种方法在 JavaScript 中交换两个变量的值。让我们通过示例了解交换的含义。例如,我们有两个名为 variable1 和 variable2 的变量。当我们将 variable2 的值赋给 variable1,并将 variable1 的值赋给 variable2 时,可以说我们已经交换了 variable1 和 variable2 的值。
使用临时变量
我们可以创建一个临时变量,即任何变量来暂时存储第一个变量的值。之后,我们可以将第二个变量的值赋给第一个变量。接下来,我们可以从临时变量中获取第一个变量的值并将其赋给第二个变量。
语法
用户可以按照以下语法使用临时变量来交换两个变量的值。
let temporaryVariable = variable1; variable1 = variable2; variable2 = temporaryVariable;
在上面的语法中,我们将 variable1 的值存储到 temporaryVariable 中。之后我们将 variable2 的值赋给 variable1,并将 temporaryVariable 的值赋给 variable2。
示例
在下面的示例中,我们创建了两个变量并分配了字符串值。此外,我们使用了临时变量来交换两个变量的值。在输出中,用户可以看到 variable1 和 variable2 的值已交换。
<html> <body> <h2>Using the <i> temporary variable </i> to swap two variable values in JavaScript</h2> <div id = "output"> </div> <script> let output = document.getElementById('output'); let variable1 = "Value1"; let variable2 = "Value2"; let temporaryVariable = variable1; variable1 = variable2; variable2 = temporaryVariable; output.innerHTML += "The value of the variable1 and variable2 after swaping are the <br/>"; output.innerHTML += "variable1 = " + variable1 + " variable2 = " + variable2; </script> </body> </html>
使用解构赋值属性
在 JavaScript 的 ES6 版本中,引入了数组或对象的解构。在数组解构中,我们可以将数组值存储到其他变量或同一变量中。在这里,我们将创建两个变量的数组并解构数组以交换两个变量。
语法
用户可以按照以下语法使用数组解构属性来交换两个变量。
[var2, var1] = [var1, var2];
在上面的语法中,我们将 var1 的值赋给了 var2,var2 的值赋给了 var1。
示例
在下面的示例中,我们使用了 var1 和 var2。之后,我们使用 var1 和 var2 创建了两个变量的数组。在解构数组时,我们将 var1 的值赋给 var2 变量,将 var2 的值赋给 var1 变量。
<html> <body> <h2>Using the <i>Assignment destructuring property</i> to swap two variable values in JavaScript </h2> <div id="output"> </div> <script> let output = document.getElementById('output'); let var1 = 20; let var2 = 10; function swapVariables() { [var2, var1] = [var1, var2]; output.innerHTML += "The value of the var1 and var2 after swaping are the <br/>"; output.innerHTML += "var1 = " + var1 + " var2 = " + var2; } swapVariables() </script> </body> </html>
使用算术运算符
我们可以使用乘法和除法算术运算符来交换两个数字。为了交换两个变量,我们可以对两个数字值执行算术运算。
语法
用户可以按照以下语法使用算术运算符来交换两个数字变量的值。
num1 = num1 * num2; num2 = num1 / num2; num1 = num1 / num2;
在上面的语法中,我们首先将两个数字相乘并将结果存储在 num1 变量中。之后,我们将新的 num1 变量 (num1 * num2) 除以 num2 变量并将结果存储在 num2 变量中。接下来,我们将更新后的 num1 (num1*num2) 除以更新后的 num2 并将其存储在 num1 变量中。
示例
在下面的示例中,swapNumbers() 函数交换两个数值。在下面的示例输出中,用户可以观察到 num1 和 num2 变量的初始值以及交换两个变量后的值。
<html> <body> <h2>Using the <i>Arithmetic operators</i> to swap two variable values in JavaScript</h2> <div id = "output"> </div> <button onclick = "swapNumbers()"> Swap variables </button> <script> let output = document.getElementById('output'); function swapNumbers() { let num1 = 2; let num2 = 4; output.innerHTML += output.innerHTML += "num1 = " + num1 + " num2 = " + num2 + "<br/>"; num1 = num1 * num2; // num1 == 8 (2*4) num2 = num1 / num2; // num2 == 2 (8/4) num1 = num1 / num2; // num1 == 4, (8/2) output.innerHTML += "The value of the num1 and num2 after swaping are the <br/>"; output.innerHTML += "num1 = " + num1 + " num2 = " + num2; } </script> </body> </html>
使用按位异或运算符
当我们对任何数值执行异或运算时,它会返回零。因此,我们将使用按位异或运算符的该属性来交换两个值。
语法
用户可以按照以下语法使用按位异或运算符来交换两个数字。
num1 = num1 ^ num2; // num1 == num1 ^ num2 num2 = num1 ^ num2; // num2 == (num1 ^ num2) ^ num2 == num1 num1 = num1 ^ num2; // num1 == (num1 ^ num2) ^ num1 == num2
在上面的语法中,我们执行了 num1 和 num2 的按位异或运算三次来交换 num1 和 num2 变量的值。
示例
在下面的示例中,当用户单击“交换变量”按钮时,将弹出提示框以获取数字输入。之后,在输出中,用户可以看到交换后的数值。
<html> <body> <h2>Using the <i>Bitwise XOR operator</i> to swap two variable values in JavaScript</h2> <div id="output"> </div> <button onclick = "swapNumbers()">Swap variables</button> <script> let output = document.getElementById('output'); function swapNumbers() { let num1 = prompt("Enter first number value", 10); let num2 = prompt("Enter second number value", 20); output.innerHTML += output.innerHTML += "num1 = " + num1 + " num2 = " + num2 + "<br/>"; num1 = num1 ^ num2; num2 = num1 ^ num2; num1 = num1 ^ num2; output.innerHTML += "The value of the num1 and num2 after swaping are the <br/>"; output.innerHTML += "num1 = " + num1 + " num2 = " + num2; } </script> </body> </html>
用户可以使用第一种和第二种方法来交换所有变量,例如字符串、布尔值、数字等。第三种和第四种方法仅适用于排序数值。