我需要一个JavaScript日志函数,但它需要以10为基数。我看不到任何关于这个的列表,所以我假设这是不可能的。有没有数学奇才知道这个问题的答案?
当前回答
const logBase = (n, base) => Math.log(n) / Math.log(base);
https://en.wikipedia.org/wiki/Logarithm#Change_of_base
其他回答
Math.log10 = function(n) {
return (Math.log(n)) / (Math.log(10));
}
然后你就可以
Math.log10(your_number);
注:最初我想做Math.prototype。Log10 =…但是用户CMS指出Math不是这样工作的,所以我编辑掉了.prototype部分。
你可以简单地除以你的值的对数,和你想要的底的对数,你也可以重写Math.log方法来接受一个可选的底参数:
Math.log = (function() {
var log = Math.log;
return function(n, base) {
return log(n)/(base ? log(base) : 1);
};
})();
Math.log(5, 10);
这里的答案会导致明显的精度问题,并且在某些用例中不可靠
> Math.log(10)/Math.LN10
1
> Math.log(100)/Math.LN10
2
> Math.log(1000)/Math.LN10
2.9999999999999996
> Math.log(10000)/Math.LN10
4
如果你有一个数字x,那么Math.log(x)的使用本质上就是lnx。
要将它转换为e以外的基数,可以使用以下函数:
function(x){ return Math.log(x)/Math.log(10); }
FF 25+支持数学。log10方法。您可以使用polyfill:
if (!Math.log10) Math.log10 = function(t){ return Math.log(t)/Math.LN10; };
MDN列出了支持的浏览器。
桌面浏览器 Chrome Firefox (Gecko) Internet Explorer Opera Safari 38 25(25)不支持 移动浏览器 Android Chrome for Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile 不支持不支持25.0(25)不支持iOS 8
推荐文章
- JavaScript: override alert()
- 重置setTimeout
- 如何确保<select>表单字段被禁用时提交?
- jQuery有不聚焦的方法吗?
- 反应钩子-正确的方式清除超时和间隔
- TypeScript枚举对象数组
- 在React.js中正确的img路径
- 在React.js中更新组件onScroll的样式
- onClick ReactJS调用多个函数
- 如何在JavaScript中转义单引号(')?
- Ng-repeat结束事件
- 谷歌MAP API未捕获的类型错误:无法读取属性“offsetWidth”为空
- 模糊vs聚焦-有什么真正的区别吗?
- 如何使用JavaScript创建和样式一个div ?
- 清除JavaScript中的缓存