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 进行搜索
    // ...
}

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

相关推荐
Ws_3 小时前
C#学习 Day2
开发语言·学习·c#
杰克尼3 小时前
天机学堂复习总结(day03-day04)
java·开发语言·redis·elasticsearch·spring cloud
tedcloud1234 小时前
RTK部署教程:构建稳定的AI Workflow环境
服务器·javascript·人工智能·typescript·ocr
x***r1514 小时前
jdk-11.0.16.1_windows使用步骤详解(附JDK 11环境变量配置与验证教程)
java·开发语言·windows
luck_bor5 小时前
File类&递归作业
java·开发语言
努力努力再努力wz8 小时前
【Qt入门系列】:按钮组件全解析:从 QAbstractButton 到快捷键事件、单选与复选机制
c语言·开发语言·数据结构·c++·git·qt·github
skywalk81639 小时前
言知(Yanzhi)系统提升建议报告和完工报告 by AutoCoder
开发语言·编程
yunn_9 小时前
单例模式两种实现方法
开发语言·c++·单例模式
我材不敲代码9 小时前
Python基础:列表详解、增删改查及常用高阶操作
开发语言·windows·python
zithern_juejin9 小时前
new 运算符
javascript