热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

前端取object数据(ajax返回的数据怎么在前端取到)

如果有老司机告诉你,用num|0取整是最简单的方式,你能反驳TA,说出这其中隐藏的坑吗在处理数值的时候,获取浮点数的整数和小数部分,是一种常见的操作,在JavaScript中有许多


如何优雅地得到一个数的整数和小数部分?这个问题看似简单,其实很有学问。如果一个老司机告诉你用num|0舍入是最简单的方法,你能反驳TA,说出隐藏的坑吗?


在处理数值时,获取浮点数的整数和小数部分是一种常见的操作。在Javascript中实现目的的方法有很多,但正是因为方法多,哪种方法更好值得我们仔细研究。


舍入数字


ParseInt常用于取整数部分,在一些项目中经常可以看到:


设num=3.75


console . log(ParSeint(num));//3


num=-3.75;


console . log(ParSeint(num));//-3


用parsent取整数,结果是没问题的,但严格来说,parsent并不是为了取整数而设计的。


知识点:parseInt(字符串,基数)这个方法是将字符串转换为整数的方法。它有两个参数。第一个参数表示要转换的字符串,如果该参数不是字符串,它将被转换为字符串。第二个参数是基数或小数,默认值是10。


所以实际上,代码parseInt(3.75)将首先把3.75转换成字符串‘3.75’,然后把它变成parseInt 3。


因此,使用parseInt方法获取整数有两个缺点。一个是函数名parseInt,看起来是一种将字符串转换成整数的方法,不太适合在这里使用。另一个是转换字符串有点多余,肯定会带来性能开销,所以使用parseInt很方便,但不是最好的方法。


然后,有经验的学生会想到用数学来凑凑数。有三种相关的方法,即数学天花板,数学圆形和数学地板


其中,数学。圆形被舍入,数学。天花板被向上舍入,数学。地板被向下舍入。


为了得到parseInt的结果,我们需要判断数值的符号。如果是负数,使用Math.ceil如果它是正的,使用数学。地板:


函数trunc(num){ 0


if(num=0)返回math . floor(num);


返回Math . ceil(num);


}


console . log(trunc(3.75));//3


console . log(trunc(-3.75));//-3


使用Math.round和Math.ceil实现trunc方法比使用parseInt性能更好,因为省略了转换字符串。我们可以用jsperf进行测试:


结果如下:图:




显然看数学更快。地板数学。天花板。


其实在ES2015之后,我们也提供了原生的Math.trunc,我们可以更方便的使用math.trunc,而不是用Math.floor和Math.ceil自己实现:


console . log(Math . trunc(3.75));//3


console . log(Math . trunc(-3.75));//-3


狡猾的


如果您查看一些库的代码,您可能会看到这种舍入方式:


设num=3.75


console . log(num | 0);//3


num=-num;


console . log(num | 0);//-3


这是一种按位舍入或“|”运算的方法。老司机经常用,我也用过。


为什么这样就能达到我们的效果?详情请参考ECMA-262文件。




在对位操作的过程中,首先

5、6步,会把操作数转为Int32,所以我们就可以利用这个特点来使用“|”操作符了。

不过这么做也是有缺陷的,你发现问题了吗?

矮小的酸奶:因为bitwise操作将操作数转为Int32,所以它不能处理超过32位的数值取整,而Javascript有效整数的范围是53位。

const num = 17179869184.89;
console.log(num | 0); // 0
console.log(Math.trunc(num)); // 17179869184

那么用“|”有什么好处呢?如果考虑js文件大小,那么a|0与其他方式比较,是最短的方式,所以如果要考虑压缩代码的大小,且明确知道数值范围不会超过32位整数的时候,可以考虑使用这个技巧。

取小数

取了整数部分,接下来取小数部分就很简单了:

function fract(num) {
return num - Math.trunc(num);
}
console.log(fract(3.75)); // 0.75
console.log(fract(-3.75)); // -0.75

上面的代码思路就是先用Math.trunc(num)取整,然后再与原数相减,就得到了小数部分。

但是,我们还有更加简单的办法:

知识点:Javascript的取模运算%并不限于整数运算,可以对浮点数取模。

所以,直接将原数对1取模,即可获得小数部分!

console.log(3.75 % 1); // 0.75
console.log(-3.75 % 1); // -0.75

这是最简单的取小数的方式,然后反过来,还可以倒推出另一种实现trunc取整的方式:

function trunc(num) {
return num - num % 1;
}

扩展

取小数部分,可以用来实现周期函数,比如实现匀速的js周期动画:


#progress_bar {
display: inline-block;
width: 0px;
height: 20px;
background: red;
}
function run(el, duration) {
const startTime = Date.now();
function update() {
let p = (Date.now() - startTime) / duration;
p %= 1;
el.style.width = `${300 * p}px`;
requestAnimationFrame(update);
}
update();
}
const bar = document.getElementById('progress_bar');
run(bar, 3000);

如果我们的周期函数要考虑负数那一半区间,其实fract的方式要修改一下:

function fract(num) {
return num - Math.floor(num);
}

这个方式才是正确的周期,它和之前的实现区别是负数区间返回的值不同,前者负数返回的小数部分为负数,这个实现中,如果num是正数,返回num的小数部分,如果num是负数,返回1.0 + num的负数小数部分,这样就保证返回值始终在0.0~1.0的区间内。

function fract(num) {
return num - Math.floor(num);
}
console.log(-3.75 % 1); // -0.75
console.log(fract(num)); // 0.25

好了,关于取整和取小数的讨论就到这里。如果你们还有哪些关于取整和取小数的问题,欢迎在issue中讨论。

文章来源:https://dwz.cn/1CBiJGRQ 作者:月影前端
推荐阅读
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 在JavaWeb开发中,文件上传是一个常见的需求。无论是通过表单还是其他方式上传文件,都必须使用POST请求。前端部分通常采用HTML表单来实现文件选择和提交功能。后端则利用Apache Commons FileUpload库来处理上传的文件,该库提供了强大的文件解析和存储能力,能够高效地处理各种文件类型。此外,为了提高系统的安全性和稳定性,还需要对上传文件的大小、格式等进行严格的校验和限制。 ... [详细]
  • 本文深入解析了 jQuery 中用于扩展功能的三个关键方法:`$.extend()`、`$.fn` 和 `$.fn.extend()`。其中,`$.extend()` 用于扩展 jQuery 对象本身,而 `$.fn.extend()` 则用于扩展 jQuery 的原型对象,使自定义方法能够作为 jQuery 实例的方法使用。通过这些方法,开发者可以轻松地创建和集成自定义插件,增强 jQuery 的功能。文章详细介绍了每个方法的用法、参数及实际应用场景,帮助读者更好地理解和运用这些强大的工具。 ... [详细]
  • 本文详细探讨了 jQuery 中 `ajaxSubmit` 方法的使用技巧及其应用场景。首先,介绍了如何正确引入必要的脚本文件,如 `jquery.form.js` 和 `jquery-1.8.0.min.js`。接着,通过具体示例展示了如何利用 `ajaxSubmit` 方法实现表单的异步提交,包括数据的发送、接收和处理。此外,还讨论了该方法在不同场景下的应用,如文件上传、表单验证和动态更新页面内容等,提供了丰富的代码示例和最佳实践建议。 ... [详细]
  • 十三、实现模糊查询功能
    本文介绍了在index.jsp页面中实现模糊查询功能的具体步骤,包括添加必要的HTML元素和JavaScript代码。 ... [详细]
  • 本文详细介绍了在编写jQuery插件时需要注意的关键要点,包括模块化支持、命名规范和性能优化等内容,旨在帮助开发者提高插件的质量和可维护性。 ... [详细]
  • javascript分页类支持页码格式
    前端时间因为项目需要,要对一个产品下所有的附属图片进行分页显示,没考虑ajax一张张请求,所以干脆一次性全部把图片out,然 ... [详细]
  • 在PHP中如何正确调用JavaScript变量及定义PHP变量的方法详解 ... [详细]
  • 技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统
    技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
  • 本文详细解析了ASP.NET 2.0中的Callback机制,不仅介绍了基本的使用方法,还深入探讨了其背后的实现原理。通过对比Atlas框架,帮助读者更好地理解和应用这一机制。 ... [详细]
  • 单元测试:使用mocha和should.js搭建nodejs的单元测试
    2019独角兽企业重金招聘Python工程师标准BDD测试利器:mochashould.js众所周知对于任何一个项目来说,做好单元测试都是必不可少 ... [详细]
author-avatar
诚实的大丈夫_196
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有