2025-12-26-JavaScript 数字,数组,字符串的处理

659 个字
3 分钟
2025-12-26-JavaScript 数字,数组,字符串的处理

字符串,数组,数字的转换#

数字(Number)字符串(String)数组(Array) 之间的相互转换算是常见操作了,常见转换方向、推荐方法、示例代码及说明如下:

从 → 到方法示例代码说明
Number → StringString(num) 或 num.toString()let str = String(123); // “123” let str = (123).toString(); // “123”最可靠方式。toString() 可指定进制,如 (10).toString(2) // “1010”。
Number → ArrayString(num).split(”)let arr = String(123).split(”); // [“1”, “2”, “3”]先转为字符串,再按字符拆分成数组(适用于单个数字的位拆分)。
String → NumberNumber(str) 或 +str 或 parseInt(str, 10)let num = Number(“123”); // 123 let num = +“123”; // 123 let num = parseInt(“123”, 10); // 123+str 最简洁;parseInt 适合提取整数部分(忽略后缀非数字)。
String → Arraystr.split(separator)let arr = “1,2,3”.split(’,’); // [“1”, “2”, “3”] let arr = “123”.split(”); // [“1”, “2”, “3”]split(”) 按单个字符拆分;split(’,’) 按逗号等分隔符拆分。
Array → Stringarr.toString() 或 arr.join(separator)let str = [1,2,3].toString(); // “1,2,3” let str = [1,2,3].join(”); // “123” let str = [1,2,3].join(’-’); // “1-2-3”join() 更灵活,可自定义分隔符(默认逗号)。
Array → Number先转为字符串,再转为数字(如 Number(arr.join(”)))let num = Number([1,2,3].join(”)); // 123适用于纯数字数组;若数组含非数字,返回 NaN。
Array(Number) → Array(String)arr.map(String) 或 arr.map(num => num.toString())let strArr = [1,2,3].map(String); // [“1”, “2”, “3”]逐元素转换为字符串,最常用方法。
Array(String) → Array(Number)arr.map(Number) 或 arr.map(str => parseInt(str, 10))let numArr = [“1”,“2”,“3”].map(Number); // [1, 2, 3]逐元素转换为数字;parseInt 更安全处理可能含非纯数字字符串。

数组转数字本质是拼接字符串

const arr = ["2", "1", "22", "23"];
// 步骤1: 使用 join('') 无分隔符拼接成字符串 const str = arr.join(''); // "212223"
// 步骤2: 转换为数字 const num = Number(str); // 212223 // 或等价简写:const num = +arr.join('');
console.log(num); // 212223(number 类型)

数组转连续字符串本质也是拼接字符串

const arr: string[] = ['X', 'W', 'W'];
// 使用 join('')(最常用)
const str: string = arr.join(''); // "XWW"
// 使用 join() 无参数(默认逗号,但空字符串等价)
const str2: string = arr.join(); // 注意:默认会得到 "X,W,W",必须传空字符串

字符串反转:#

ES6:

const reverseString = (str: string): string => str.split("").reverse().join("");
// 使用示例
console.log(reverseString("hello")); // 'olleh'

手动循环(不依赖内置方法):

function reverseString(str) {
let reversed = '';
for (let i = str.length - 1; i >= 0; i--) {
reversed += str[i];
}
return reversed;
}

数组反转(Array Reverse):#

原地反转

const arr = [1, 2, 3, 4];
arr.reverse(); // arr 变为 [4, 3, 2, 1]

手动实现

function reverseArray(arr) {
let left = 0, right = arr.length - 1;
while (left < right) {
[arr[left], arr[right]] = [arr[right], arr[left]];
left++;
right--;
}
return arr;
}

数字反转(leetcode # 7)#

function reverseInt(x) {
const sign = x < 0 ? -1 : 1;
const reversed =
sign *
parseInt(Math.abs(x).toString().split("").reverse().join(""), 10);
return reversed;
}

补充:#

数组排序

nums.sort((a, b) => a - b);

分享到社交平台

将本文分享给你的朋友们

2025-12-26-JavaScript 数字,数组,字符串的处理
https://firefly.cuteleaf.cn/posts/2025-12-26-javascript-数字数组字符串的处理/
作者
Zhongye
发布于
2025-12-26
版权声明
CC BY-NC-SA 4.0

评论

Profile Image of the Author
Zhongye
南漂中
公告
新的博客站!旧站点传送门 zhongye1.github.io/Arknight-notes
音乐
专辑封面

音乐

暂无播放

0:00 0:00
暂无歌词
分类
标签
站点统计
文章数
142
分类数
14
标签数
214
总字数
339,690
运行天数
0
最后更新
0 天前

目录