JavaScript 字符串转数值(小数)

在 JavaScript 中,将字符串转换为数值(包括小数)有多种方法。以下是常用的几种方式:

1. parseFloat() - 最常用的方法

javascript 复制代码
let str = "123.45";
let num = parseFloat(str); // 123.45 (number类型)
console.log(typeof num); // "number"

2. Number() 构造函数

javascript 复制代码
let str = "123.45";
let num = Number(str); // 123.45 (number类型)
console.log(typeof num); // "number"

3. 一元加号运算符(+)

javascript 复制代码
let str = "123.45";
let num = +str; // 123.45 (number类型)
console.log(typeof num); // "number"

4. parseFloat() 与 toFixed() 结合使用

javascript 复制代码
let str = "123.45678";
let num = parseFloat(str).toFixed(2); // "123.46" (string类型)
let num2 = parseFloat(parseFloat(str).toFixed(2)); // 123.46 (number类型)

实际应用示例

javascript 复制代码
// 从输入框获取值并转换为数值
let inputValue = document.getElementById("priceInput").value; // 假设值为 "123.45"
let price = parseFloat(inputValue); // 转换为数值 123.45

// 计算时使用数值
let total = price * 1.05; // 正确的数值计算

// 显示时格式化
document.getElementById("display").textContent = total.toFixed(2); // "129.62"

注意事项

  1. 无效值处理 :如果字符串不能转换为有效数字,会返回 NaN

    javascript 复制代码
    let invalid = parseFloat("abc"); // NaN
  2. 空字符串处理:空字符串会转换为 0

    javascript 复制代码
    let empty = parseFloat(""); // 0
  3. 部分数字字符串:parseFloat 会解析直到遇到非数字字符

    javascript 复制代码
    let partial = parseFloat("123.45abc"); // 123.45
  4. toFixed() 返回字符串:注意 toFixed() 返回的是字符串,不是数值

    javascript 复制代码
    let num = 123.456;
    let str = num.toFixed(2); // "123.46" (字符串)
    let num2 = parseFloat(num.toFixed(2)); // 123.46 (数值)

在您的代码中的应用

根据您提供的代码,您已经在多处使用了 toFixed(2) 来格式化显示数值,这是正确的做法。如果您需要将用户输入的字符串转换为数值进行计算,可以使用上述方法。

例如,在您的搜索功能中:

javascript 复制代码
function stock_search(btn) {
    let inputValue = document.getElementById("stock_search_input").value;
    // 如果需要确保是数值,可以转换
    let stockCode = parseInt(inputValue); // 如果是整数股票代码
    // 或者保持为字符串,取决于您的后端API要求
    
    // 然后使用 stockCode 进行搜索
    // ...
}

希望这些信息对您有帮助!

相关推荐
三品吉他手会点灯6 小时前
C语言学习笔记 - 50.流程控制4 - 流程控制为什么非常非常重要
c语言·开发语言·笔记·学习
武清伯MVP9 小时前
前端跨域方案大合集
前端·javascript
在放️9 小时前
Python 爬虫 · 第三方代理接入与合规使用
开发语言·爬虫·python
KANGBboy9 小时前
java知识五(继承)
java·开发语言
c++之路9 小时前
Bazel C++ 构建系列文档(三):构建第一个 C++ 项目
开发语言·c++
AI人工智能+电脑小能手9 小时前
【大白话说Java面试题 第117题】【并发篇】第17题:线程有几种状态,之间如何转换?
java·开发语言·面试
星星在线9 小时前
我是怎么把页面图片流量砍掉一半的
前端·javascript
聚名网10 小时前
域名net,com,cn有区别吗?有哪些不同呢?
服务器·开发语言·php
牛油果子哥q10 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
foundbug99910 小时前
直流电机 PID 速度控制 MATLAB 仿真程序
开发语言·matlab