javascript如何转换int型(浅谈JavaScript中的parseInt的妙用)
类别:编程学习 浏览量:304
时间:2021-10-10 00:59:48 javascript如何转换int型
浅谈JavaScript中的parseInt的妙用起因写这篇博客的起因是今天在刷leetcode的每日一题,是一道字符串转换整数 (atoi)的题,感兴趣的话可以点击题目名称去看一下具体描述。在我多次debug终于成功提交之后,去评论区看了一下大佬们的解题思路,看完之后不禁感叹javascript中原来parseInt( )已经这么优秀了啊。这告诉我了一个道理,我们自认为再熟悉不过的api,可能我们并没有真正意义上的掌握。”
我的解答/** * @param {string} str * @return {number} */ var myAtoi = function(str) { str = str.trim(); //截取字符串第一个字符 var firstChar = str.charAt(),res = '',regSymbol = /^[\-\+]{1}/,regNumber = /^[0-9]{1}/; if(!regSymbol.test(firstChar) && !regNumber.test(firstChar)){ return 0; } //第一个字符为+或者- if(regSymbol.test(firstChar)){ var sliceStr = str.slice(1,str.length); for(var i=0;i<sliceStr.length;i++){ if(regNumber.test(sliceStr.charAt(i))){ res += sliceStr.charAt(i); }else{ break; } } (res.length) ? res = parseInt(firstChar + res) : res = 0; if(firstChar == '-' && res < Math.pow(-2,31)){ res = Math.pow(-2,31); } if(firstChar == '+' && res > Math.pow(2,31) - 1){ res = Math.pow(2,31) - 1; } return res; } //第一个字符为数字 if(regNumber.test(firstChar)){ var sliceStr = str; for(var i=0;i<sliceStr.length;i++){ if(regNumber.test(sliceStr.charAt(i))){ res += sliceStr.charAt(i); }else{ break; } } if(parseInt(res) > Math.pow(2,31) - 1){ res = Math.pow(2,31) - 1; } return res; } };
/** * @param {string} str * @return {number} */ var myAtoi = function(str) { const number = parseInt(str, 10); if(isNaN(number)) { return 0; } else if (number < Math.pow(-2, 31) || number > Math.pow(2, 31) - 1) { return number < Math.pow(-2, 31) ? Math.pow(-2, 31) : Math.pow(2, 31) - 1; } else { return number; } };
通过对比,我们了解到javascript中的parseInt()已经做了截取空字符串、首字母判断、number类型结果返回等一系列操作。刚好与今天的每日一题的需求完美契合,使用parseInt()来解决这个题目简直不要太爽。
到此这篇关于浅谈JavaScript中的parseInt()的妙用的文章就介绍到这了,更多相关JavaScript parseInt()内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- hashtable的javascript实现
- js 定时切换图片(JavaScript定时器实现无缝滚动图片)
- 用css实现图片特效代码(HTML+CSS+JavaScript实现图片3D展览的示例代码)
- javascript 数组排序
- html基础知识javascript(JavaScript+html实现前端页面滑动验证)
- javascript 开发网站(帮你提高开发效率的JavaScript20个技巧)
- js中alert加参数写法(详解JavaScript Alert函数执行顺序问题)
- 百度地图获取api过程(JavaScript接入百度地图API的方法步骤)
- js 图片编辑处理库(javascript input图片上传及预览,FileReader预览图片)
- JavaScriptSerializer对Json对象的序列化和反序列化
- javascript数组实例扩展方法(JavaScript如何监测数组的变化)
- javascript 经典算法(JavaScript实现的七种排序算法总结推荐!)
- javascript执行类的所有方法(Javascript中异步等待的深入理解)
- javascript中定义数组的方法(JavaScript中数组sort方法的基本使用与踩坑记录)
- javascript和jquery的区别详解(JavaScript与JQuery框架基础入门教程)
- javascript的执行原理(一文读懂JavaScript 中的延迟加载属性模式)
- 吉林舒兰 封城 聚集性疫情传播链已延至沈阳,有一个细节让人忧心(吉林舒兰封城)
- 1天密接者猛增77人,患者轨迹透露危险信号 吉林市全面封闭管理(1天密接者猛增77人)
- 吉林舒兰 封城 15人确诊 276人隔离,出现跨省传播(吉林舒兰封城)
- 四月新番CP人气榜公布,《剃须》两度上榜,沙优不是女朋友(四月新番CP人气榜公布)
- 2019年外媒秋季新番动画角色CP排行榜,桐人和爱丽丝落榜(2019年外媒秋季新番动画角色CP排行榜)
- 新一小兰领衔 盘点动漫中的那些 远距离恋爱情侣(盘点动漫中的那些)
热门推荐
- dedecms怎样实现(dedecms 5.6修改Dedecms提示信息方法)
- nginx https 域名配置(阿里云Nginx配置https实现域名访问项目图文教程)
- windows7mysql服务无法启动(Windows系统下MySQL无法启动的万能解决方法)
- apache中配置虚拟主机的作用(apache基于端口创建虚拟主机的示例)
- amazeui图标(AmazeUI 折叠面板的实现代码)
- 面试如何回答 5年内职业规划是什么?
- python列表切片和分片(Python列表切片操作实例总结)
- 云服务器安全么(云服务器如何识别真假)
- idea配置mysql最大连接数(IDEA连接不上MySQL端口号占用的解决)
- laravel循环插入数据(Laravel 实现关系模型取出需要的字段)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9