面试官问获取字符串的字节长度,我直接说点length

1 这是一道面试题

昨天老张顶着烈日去面试了,今天早上我刚一来公司,

他就赶紧悄悄问我:你知道怎么获取一个字符串的字节长度吗?

我说,这个字节长度,难道不是所谓的点length吗?这不是字符串的基本属性吗?

他说不是,昨天面试官问他了,他也说点length,但面试官当时的表情,很明显就是错了。

我还是不太信,所以在电脑上试了一下

ini 复制代码
const str1 = 'Hello world!!!';
const str2 = '我是The first one,😶 HaHa~';
console.log('第一个字符串的长度:', str1.length);
console.log('第一个字符串的长度:', str2.length);

看着好像是不太对啊。

2 获取字符串长度和字节长度的不同

后来我们又赶紧问了一下组里的老懂,他是组里的懂哥,希望他会。懂哥给我们介绍说:

字符串长度是指字符串中字符的数量,也不是字节数的数量啊,单纯说的是字符的数量。而字节长度是指字符串在特定编码下占用的字节数。

字符串长度,我们平时就是可以直接点length就可以,比如检测个密码长度啦,检测个手机号长度啦。但前几天,他们组做那个海外项目,不是经常要展示出多少字节嘛,就跟那个不一样啦。你们去问问他们,字节长度是咋显示的不就行了。

3 快捷获取字节长度的方法

后来我们找到了老王,老王高兴的说,哈哈,有个库,获取字节长度挺方便的。

3.1 安装js-tool-big-box工具库

执行安装命令

npm install js-tool-big-box

3.2 引入 stringBox 对象

获取字节长度的公共方法,就在这个对象下面,是 byteLength 方法。

javascript 复制代码
import { stringBox } from 'js-tool-big-box';

3.3 获取字节长度

引入stringBox对象后,就可以使用这个方法,获取字节长度了,挺方便的。拿我们刚才那2个字符串举例呢就是:

ini 复制代码
    const str1 = 'Hello world!!!';
    const str2 = '我是The first one,😶 HaHa~';
    const str1ByteLength = stringBox.byteLength(str1);
    const str2ByteLength = stringBox.byteLength(str2);
    console.log('Hello world!!!的字节长度是:', str1ByteLength);
    console.log('我是The first one,😶 HaHa~:', str2ByteLength);

你看,结果立马就不一样了。

4 最后

后来,我和老张的项目里也用到了获取字节长度的场景,我们快速的使用了js-tool-big-box这个工具库,不管在Vue项目里,还是React项目里,使用起来都很方便快捷。

相关推荐
Warren983 小时前
Lua 脚本在 Redis 中的应用
java·前端·网络·vue.js·redis·junit·lua
mCell3 小时前
JavaScript 运行机制详解:再谈 Event Loop
前端·javascript·浏览器
amy_jork5 小时前
npm删除包
开发语言·javascript·ecmascript
legendary_bruce6 小时前
【22-决策树】
算法·决策树·机器学习
帧栈7 小时前
开发避坑指南(27):Vue3中高效安全修改列表元素属性的方法
前端·vue.js
max5006007 小时前
基于桥梁三维模型的无人机检测路径规划系统设计与实现
前端·javascript·python·算法·无人机·easyui
excel7 小时前
使用函数式封装绘制科赫雪花(Koch Snowflake)
前端
我命由我123458 小时前
软件开发 - 避免过多的 if-else 语句(使用策略模式、使用映射表、使用枚举、使用函数式编程)
java·开发语言·javascript·设计模式·java-ee·策略模式·js
萌萌哒草头将军8 小时前
Node.js v24.6.0 新功能速览 🚀🚀🚀
前端·javascript·node.js
AALoveTouch9 小时前
大麦APP抢票揭秘
javascript