当前位置: 首页 > news >正文

js 字符串功能转换解析

一. 字符串转换

1.1. 对象转字符串stringify

var str = JSON.stringify(weather);

1.2. 字符串转对象

var obj = JSON.parse(str);

1.3. 数字转字符串toString()

var num = 2023;
var str = '';
str = num.toString();

1.4. 字符串转数字parseInt(string)

parseInt('123'),返回的结果就是int型的123
parseInt('123abc'),返回的结果就是12

1.5. 字符串转数字parseInt(string)和parseFloat()

  前者把值转换成整数,后者把值转换成浮点数

parseInt('123')//返回的结果就是int型的123
parseInt('123abc')//返回的结果就是123
parseFloat('123.4abc')//返回的结果就是123.4

  parseInt()方法还有基模式,可以把二进制、八进制、十六进制或其他任何进制的字符串转换成整数。基是由parseInt()方法的第二个参数指定的,示例如下:

console.log('数字:', parseInt("AF", 16));  //returns 175
console.log('数字:', parseInt("10", 2));   //returns 2
console.log('数字:', parseInt("10", 8));  //returns 8
console.log('数字:', parseInt("10", 10));  //returns 10

二. 其他类型转换

2.1. 强制类型转换

  强制类型转换(type casting)处理转换值的类型。使用强制类型转换可以访问特定的值,即使它是另一种类型的。
  ECMAScript中可用的3种强制类型转换如下:
  Boolean(value)——把给定的值转换成Boolean型;
  Number(value)——把给定的值转换成数字(可以是整数或浮点数);
  String(value)——把给定的值转换成字符串。

Boolean型的强制类型转换代码

console.log('强制类型转换:', Boolean(""))     //false – empty string   
console.log('强制类型转换:', Boolean("hi"))   //true – non-empty string  
console.log('强制类型转换:', Boolean(100))    //true – non-zero number 
console.log('强制类型转换:', Boolean(null))   //false - null  
console.log('强制类型转换:', Boolean(0))      //false - zero  
console.log('强制类型转换:', Boolean(new Object())) //true – object  

2.2. Number()的强制类型转换代码

  与parseInt()和parseFloat()方法的处理方式相似

console.log('强制类型转换:', Number(false))     //0
console.log('强制类型转换:', Number(true))      //1
console.log('强制类型转换:', Number(undefined)) //NaN
console.log('强制类型转换:', Number(null))      //0
console.log('强制类型转换:', Number("5.5 "))    //5.5
console.log('强制类型转换:', Number("56 "))     //56
console.log('强制类型转换:', Number("5.6.7 "))  //NaN
console.log('强制类型转换:', Number(new Object())) //NaN
console.log('强制类型转换:', Number(100))          //100 

2.3. 利用js变量弱类型转换

  对数字处理,保留小数点后数字 toFixed() (toFixed() 函数会四舍五入)

var num = 2.446242342;
num = num.toFixed(2); 
console.log('输出结果:', num) // 输出结果: 2.45   

  对数字处理,保留小数点后数字 (不四舍五入)

var num2 = Math.floor(15.7784514000 * 100) / 100
console.log('输出结果:', num2) // 输出结果为 15.77  

三.判断字符串中是否包含某个字符串

3.1. indexOf

  indexOf 返回指定字符串在该字符中首次出现的位置,如果没有找到,则返回 -1
  indexOf 接收两个参数,第一是需要搜索的字符串,第二个参数是检索的位置,默认为0

//str.indexOf("")的值为-1时表示不包含
var str = "hello Tara";
if(str.indexOf("Tara") !== -1){alert("Hi,Tara");
}

3.2. lastIndexOf

  lastIndexOf是从字符串末尾开始搜索,返回指定字符串在该字符中最后一次出现的位置
  lastIndexOf 接收两个参数,第一个是需要搜索的字符串,第二个参数是检索的位置,默认是 sting.length - 1

let str = 'abcdea';
//例如,从str第三位向前开始搜索 'a'
console.log(str.lastIndexOf('a',2));// 0
console.log(str.lastIndexOf('a'));// 5

3.3. includes

  lincludes() 方法用于判断字符串是否包含指定的子字符串,返回 true 或 false
  includes 接收两个参数 第一个参数为指定字符串, 第二个参数为查找位置,默认为0

//str.includes("")返回一个布尔值,值为true时表示包含
var str = "hello Tara";
if(str.includes("Tara")){alert("Hi,Tara");
}

3.4. match

  match方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配,如果未找到,则返回 null(也可以用来查询字符串中某个字符出现的次数)。全局搜索,忽略大小写。

let str = 'abcdabcda';
console.log(str.match(/a/gi));//['a','a','a']
console.log(str.match(/z/gi));// null

3.5. search

  seacrh方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,如果没有则返回 -1

let str = 'abcde';
console.log(str.search('a'));// 0
console.log(str.search(/A/i));//使用正则匹配忽略大小写检索   返回 0

3.6. 正则表达式 RegExp 对象

3.6.1. test方法

  检索字符串中指定的值。返回 true 或 false。

let str = 'abcdef';
let reg = /A/i;
console.log(reg.test(str));// true

3.6.2.exec方法

  检索字符串中指定的值。返回找到的值,并确定其位置。
  如果字符串中有匹配的值返回该匹配值,否则返回 null。

let str = 'abcdef';
console.log(/a/.exec(str))// 返回匹配对象
console.log(/z/.exec(str))// null  检索字符串中指定的值。返回 truefalse

相关文章:

  • ubuntu v2ray
  • JDBC常见的几种连接池使用(C3PO、Druid、HikariCP 、DBCP)
  • 代码随想录第三十六天(一刷C语言)|背包问题理论基础分割等和子集
  • 【稳定检索|投稿优惠】2024年区域经济与经济转型国际学术会议(IACREET 2024)
  • 2023年度佳作:AIGC、AGI、GhatGPT 与人工智能大模型的创新与前景展望
  • Elasticsearch的批量bulk 提交 写入的方式会有顺序问题吗?
  • 设计模式(三)-结构型模式(3)-装饰模式
  • 2023.12.20力扣每日一题
  • 苏宁易购商品详情API:电商实时数据
  • Linux开发工具——vim篇
  • Ubuntu系统的基础操作和使用
  • 华大基因基因检测产品PMseq®,助力应对微生物耐药带来的挑战
  • 计算机基础:网络基础
  • 基于CTF探讨Web漏洞的利用与防范
  • uni-app学习记录
  • 2017 年终总结 —— 在路上
  • AzureCon上微软宣布了哪些容器相关的重磅消息
  • IDEA常用插件整理
  • input实现文字超出省略号功能
  • Java超时控制的实现
  • Kibana配置logstash,报表一体化
  • Python 反序列化安全问题(二)
  • Redis字符串类型内部编码剖析
  • SQLServer之创建数据库快照
  • Vim Clutch | 面向脚踏板编程……
  • 闭包--闭包之tab栏切换(四)
  • 等保2.0 | 几维安全发布等保检测、等保加固专版 加速企业等保合规
  • 观察者模式实现非直接耦合
  • 汉诺塔算法
  • 记一次和乔布斯合作最难忘的经历
  • 模型微调
  • 如何正确配置 Ubuntu 14.04 服务器?
  • 推荐一个React的管理后台框架
  • 我与Jetbrains的这些年
  • 一道闭包题引发的思考
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • (2022版)一套教程搞定k8s安装到实战 | RBAC
  • (8)Linux使用C语言读取proc/stat等cpu使用数据
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (附源码)计算机毕业设计高校学生选课系统
  • (理论篇)httpmoudle和httphandler一览
  • (免费分享)基于springboot,vue疗养中心管理系统
  • (原创)攻击方式学习之(4) - 拒绝服务(DOS/DDOS/DRDOS)
  • .net CHARTING图表控件下载地址
  • .NET Core、DNX、DNU、DNVM、MVC6学习资料
  • .Net Core与存储过程(一)
  • .NET 同步与异步 之 原子操作和自旋锁(Interlocked、SpinLock)(九)
  • .NET/C# 使窗口永不激活(No Activate 永不获得焦点)
  • .Net各种迷惑命名解释
  • .net下的富文本编辑器FCKeditor的配置方法
  • @requestBody写与不写的情况
  • [8-27]正则表达式、扩展表达式以及相关实战
  • [BZOJ3211]:花神游历各国(小清新线段树)
  • [ESP32] 编码旋钮驱动