今天在匆忙的写代码过程中,测试突然跑过来跟我说,有一个小的bug,但是不能完全的复现,但确实存在。需要我们这边参与查找。首先来说一下我们这个的业务逻辑,其实非常的简单,就是一个开房间的后台,里面有一项是设置这个房间的消耗金币数。这个消耗是存在“最低消费”这个概念的。根据这个房间的不同配置,最低消费是不同的。房主可以自行更改这个消耗数,但是不能低于最低消耗。

  业务很简单,所以我们也很简单的完成了,就是把最后提交的时候,我们验证一下他这个输入的金币数大于最低消耗的金币数就可以了。因为每次房间配置的不同,我们使用ajax获取房间的最低消耗金币数。然后验证,结果有的时候就提示填写的数值小于了最低消耗数。WTF,怎么可能呢。而且这个不是稳定的复现的,有的时候行,有的时候不行。最后在我们的积极测试下,能复现这个bug了,就是房间的最低消耗是200金币,房主填写的是1200金币,这个时候提示小于最低了。也就是判断中200>1200 ???

这个时候我突然想到了什么,就是大小比较的时候,数据类型是不是出错了?肯定是,结果找到后台,发现是他们更改了数据的类型,原来的时候是number的数据类型,这次改成string类型了,而且我们写的input输入框,这里获取到的数据类型是不是number?所以就有了一下的测试。先看代码:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<style type="text/css">
input{
width: 400px;
}
</style>
</head>
<body>
<h1>为了测试数据类中的数据转换</h1>
<h4>填写一个数值和1200比较</h4>
<input type="text" name="" id="" value="" placeholder="如果填的数字小1200,提示true,否则提示false"/>
<button>比较</button>
</body>
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<script type="text/javascript">
var num1 = "1200";
$("button").on("click",function(){
var input_val = $("input").val();
console.log($.type(input_val));
console.log($.type($("input").val()));
if(num1>input_val){
alert(num1+">"+input_val);
}else{
alert(num1+"<"+input_val); }
})
</script>
</html>

  这里基本上就是在重现我们的bug,当你填入200的时候,出现了200>1200的奇观。准确的说应该是"200">"1200"。这个问题我是知道的,因为js中存在数据的隐性转换,如果你用一个字符串跟一个数字比较的话,字符串会被转换成数字类型,但是因为后台数据格式变了,所以就成了字符串与字符串比较了。字符串与字符串比较是按位比较,当第一位的时候,1小于2,所以就成了200>1200。关于这个的详细情况,请点击这里查看。这里还有一点是需要注意的,那就是我们的输入框使用的是input 这里获取的数据是string类型,虽然我们对这个输入框加了限制只能输入数字,但是这个数据类型还是string的类型。所以一本万利的办法就是在验证的时候,对这个两个变量都进行强制转换程数字。也就是在上面程序的26行改成下面的代码:

if(Number(num1)>Number(input_val)){

这样就能正确的啦!

js中关于两个变量的比较的更多相关文章

  1. 深入探究js中的隐式变量声明

    前两天遇到的问题,经过很多网友的深刻讨论,终于有一个相对可以解释的通的逻辑了,然后我仔细研究了一下相关的点,顺带研究了一下js中的隐式变量. 以下文章中提到的隐式变量都是指没有用var,let,con ...

  2. js中计算两个日期之差

    js中计算两个日期之差            var aBgnDate, aEndDate;            var oBgnDate, oEndDate;            var nYl ...

  3. php中比较两个变量是否相等的最高效写法

    <?php //php中比较两个变量是否相等的最高效写法 function isEqual($a,$b){ return $a==$b; } var_dump(isEqual(3,3));//t ...

  4. [js]js的惰性声明, js中声明过的变量(预解释),后在不会重新声明了

    js的惰性声明, js中声明过的变量(预解释),后在不会重新声明了 fn(); // 声明+定义 js中声明过一次的变量,之后在不会重新声明了 function fn() { console.log( ...

  5. js中三种定义变量 const, var, let 的区别

    js中三种定义变量的方式const, var, let的区别 1.const定义的变量不可以修改,而且必须初始化. 1 const b = 2;//正确 2 // const b;//错误,必须初始化 ...

  6. 浅谈JS中 var let const 变量声明

    浅谈JS中 var let const 变量声明 用var来声明变量会出现的问题: 1. 允许重复的变量声明:导致数据被覆盖 2. 变量提升:怪异的数据访问.闭包问题 3. 全局变量挂载到全局对象:全 ...

  7. CMake中的两种变量(Variable types in CMake)

    在CMake中存在两种变量:normal variables and cache varialbes .正常变量就像是脚本内部变量,相当于程序设计中定义的局部变量那样.而CMakeLists.txt相 ...

  8. JS中的运算符 以及变量和输入输出

    1.算术运算(单目运算符) + 加 .- 减.* 乘. / 除. % 取余.++ 自增.-- 自减. >>> +:有两种作用,链接字符串/加法运算,当+两边全为数字时,进行加法运算, ...

  9. JS中的数据类型和变量内存

    1. JS中存在5种简单数据类型和1种复杂数据类型: 5种简单数据类型:Undefined, Null, Boolean, Number, String. 1种复杂数据类型:Object. 上面的5种 ...

随机推荐

  1. 使用Git过程中经常会遇到的问题

    目录 git pull如何强制覆盖本地文件 Git如何同时删除本地分支和远程分支 Git如何撤销最近一次提交 Git撤销本地的最后一次提交 Git撤销最近一次远程提交 如何修改提交信息和文件 修改本地 ...

  2. 将一个html文件引入另一个html文件的div中

    width="" height=""属性可根据要求自己设定

  3. Android中资源的引用

    R.java简单来说就是资源 R.java会自动收录当前应用中所有的资源,并根据这些资源建立对应的ID,包括:布局资源.控件资源.String资源.Drawable资源等 可以理解把所以资源按规则存放 ...

  4. 微软推出了Cloud Native Application Bundles和开源ONNX Runtime

    微软的Microsoft Connect(); 2018年的开发者大会 对Azure和IoT Edge服务进行了大量更新; Windows Presentation Foundation,Window ...

  5. PEACHPIE 0.9.11 版本发布,可以上生产了

    PeachPie在官方博客(https://www.peachpie.io/2018/10/release-0911-visual-studio.html)发布了PeachPie的0.9.11版本 - ...

  6. 关于单元测试的思考--Asp.Net Core单元测试最佳实践

    在我们码字过程中,单元测试是必不可少的.但在从业过程中,很多开发者却对单元测试望而却步.有些时候并不是不想写,而是常常会碰到下面这些问题,让开发者放下了码字的脚步: 这个类初始数据太麻烦,你看:new ...

  7. 前端技术大行其道,再不拥抱TypeScript你就老了!

    本篇文章旨在介绍下TypeScript这门新兴的程序设计语言,不需要你有多么强的专业知识,只需要你有半支烟的功夫. 好了,废话不多说,赶紧进入正题.为什么你需要拥抱TypeScript?那么你首先需要 ...

  8. SpringBoot/SpringMVC文件下载方式

    本篇文章引用外网博客代码,共描述SpringMVC下三种文件下载方式,本人测试在SpringBoot(2.0以上版本)正常使用. 引用博客,强烈推荐https://www.boraji.com. pa ...

  9. 生产环境中学习Redis

    摘要 看到这篇文章,很有借鉴意义,因此写个读书笔记,不算是翻译.想要深入了解,请看原文http://tech.trivago.com/2017/01/25/learn-redis-the-hard-w ...

  10. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 十八║Vue基础: 指令(下)+计算属性+watch

    回顾 今天来晚辣,给公司做了一个小项目,一个瀑布流+动态视频控制的DEMO,有需要的可以联系我,公司的项目就不对外展示了(一个后端程序员真的要干前端了哈哈哈). 书接上文,昨天正式的开始了Vue的代码 ...