关于js中字符串格式的数字的几个测试

简介:

前几天写js,跟踪调试时,发现误传了参数类型【原本需要的是number类型的,结果传递的实参却是string类型的】。结果居然没有产生异常,仍然顺利地执行了。

于是,今天特地做了几个测试。

(1)字符串类型数字的自加

/*
         *测试字符串类型数字的自加操作
         */
        function testStringSelfAdd() {
            var i = "0";
            for (var j = 0; j < 100; j++) {
                i++;
            }
            alert("i=" + i + "   " + "i的类型:" + (typeof i));
        }


测试结果:


此处可以看到,对字符串格式的数字进行自加操作时,变量类型会转变为number类型。运算上也具有了和number类型变量同样的行为。

接着再来看一下,是否字符"a"在做自加运算时,会被当做97(其ASCII值)?

/*
         *测试字符串类型数字的自加操作
         */
        function testStringSelfAdd() {
            //var i = "0";
            var i="a";
            for (var j = 0; j < 100; j++) {
                i++;
            }
            alert("i=" + i + "   " + "i的类型:" + (typeof i));
        }


测试结果:


可以看到,在做自加时,变量仍然会被转型。但是,此处并非我们预期的,转化为ASCII值,而是变成了NaN。说明,非数值形式的字符串不可用来进行这种运算。

事实上,也只是++运算符上产生了字符格式的数值可以被转型为number参与运算,而这里的i++并不等同于高级强类型语言中的i=i+1; 因为这里i原本就是字符串类型,所以这里的+会被重载为连接字符串。

测试:

 /*
         *测试字符串类型数字的自加操作
         */
        function testStringSelfAdd() {
            var i = "0";
            //var i="a";
            for (var j = 0; j < 100; j++) {
                //i++;
                i = i + 1;
            }
            alert("i=" + i + "   " + "i的类型:" + (typeof i));
        }


测试结果:



(2)测试字符串类型的数值和number类型的数值的比较操作:

/*
         *测试字符串的比较
         */
        function testStringCompare() {
            var i = 4;
            alert(i < "5");     //返回true
            alert("4" == 4);    //返回true
            alert("a" == 4);    //返回false
            alert("a" != 4);    //返回true
            alert("a" < 4);     //返回false
            alert("a" > 4);     //返回false
        }


可见,字符串格式的数值在和number类型的数值进行比较时和两个number类型的数值比较无异。

因此,希望大家,下次在用的时候还是不要依赖js运算符的这些“机制”。还是,要正确地检查类型,才能构建出更安全的代码。





原文发布时间为:2011-08-16


本文作者:vinoYang


本文来自云栖社区合作伙伴CSDN博客,了解相关信息可以关注CSDN博客。

目录
相关文章
|
3月前
|
JavaScript 前端开发
JS几种拼接字符串的方法
JS几种拼接字符串的方法
69 1
|
25天前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
219 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
16天前
|
JavaScript 前端开发 开发者
JavaScript字符串的常用方法
在JavaScript中,字符串处理是一个非常常见的任务。JavaScript提供了丰富的字符串操作方法,使开发者能够高效地处理和操作字符串。本文将详细介绍JavaScript字符串的常用方法,并提供示例代码以便更好地理解和应用这些方法。
42 13
|
3月前
|
运维
【运维基础知识】用dos批处理批量替换文件中的某个字符串(本地单元测试通过,部分功能有待优化,欢迎指正)
该脚本用于将C盘test目录下所有以t开头的txt文件中的字符串“123”批量替换为“abc”。通过创建批处理文件并运行,可实现自动化文本替换,适合初学者学习批处理脚本的基础操作与逻辑控制。
245 56
|
2月前
|
JavaScript 前端开发
Moment.js与其他处理时间戳格式差异的JavaScript库相比有什么优势?
Moment.js与其他处理时间戳格式差异的JavaScript库相比有什么优势?
|
2月前
|
JavaScript 前端开发 数据处理
模板字符串和普通字符串在浏览器和 Node.js 中的性能表现是否一致?
综上所述,模板字符串和普通字符串在浏览器和 Node.js 中的性能表现既有相似之处,也有不同之处。在实际应用中,需要根据具体的场景和性能需求来选择使用哪种字符串处理方式,以达到最佳的性能和开发效率。
|
2月前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
38 2
|
2月前
|
算法 开发者
Moment.js库是如何处理不同浏览器的时间戳格式差异的?
总的来说,Moment.js 通过一系列的技术手段和策略,有效地处理了不同浏览器的时间戳格式差异,为开发者提供了一个稳定、可靠且易于使用的时间处理工具。
59 1
|
2月前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
339 1
|
3月前
|
人工智能 监控 JavaScript
模拟依赖关系和 AI 是Vue.js测试的下一个前沿领域
模拟依赖关系和 AI 是Vue.js测试的下一个前沿领域
42 1