美文网首页JS基础练习
JS基础 -- if 练习三

JS基础 -- if 练习三

作者: 我常常问自己我是谁 | 来源:发表于2018-05-08 16:49 被阅读6次

    声明:此篇简书是参照尚硅谷网站内视频而写,其内的观点是由尚硅谷视频内讲解内容以及自己理解所汇集写的,如有侵犯版权或不对的地方,请直接在下面留言,我会及时作出修改,谢谢!

    /*

    • 编写程序,由键盘输入三个整数分别存入变量num1、num2、num3,
    • 对他们进行排序,并且从小到大输出。

    • 第一步 是先声明三个函数指针

    • 第二步 就是要知道这三个函数指针的返回值类型,在这里prompt()这函数的返回值是“String”类型
      /
      // var num1 = prompt("请输入第一个数:");
      // var num2 = prompt("请输入第二个数:");
      // var num3 = prompt("请输入第三个数:");
      /

      * 这时你心里就有个疑问了,如何才能知道这三个函数指针是什么类型。虽然上面我已经说过prompt()是“String”类型
      * 但是如果我没有提前说的话,你知道怎么才能获取类型吗?????
      * 想知道函数指针是什么类型,其实,也很简单那就是用alert()打印
      * 这样写才能完整的知道 alert(typeof num1);的结果
      * alert():是一个提示框的小窗口
      * 在小括号中 typeof:是类型的意思
      * 在类型后面的 num1:是函数指针,也是返回值的载体
      /
      /

      * 现在我们知道了这三个函数指针是“string”类型的,但是,这不是我们需要的类型,我需要的是"Number"类型
      * 在这里为什么不能用“strong”类型哪?
      * 那是因为我们需要prompt()返回数字,而不是字符。在if判断里“strong”类型的返回值 会被转换成NaN,如果是NaN的话,那么我们的if判断就不会准确,也没有必要存在了
      * 那么如何才能得到 "Number"类型哪?
      * 其实,很简单在prompt()前面加上一个“+”加号,这样不论prompt()返回什么都会被转换成"Number"类型的返回值。就如下面的写法一下
      */

          var num1 = +prompt("请输入第一个数:"); 
          var num2 = +prompt("请输入第二个数:");
          var num3 = +prompt("请输入第三个数:");
      

    // alert("---:"+ num1);//这里已经不需要打印了,可以注释掉了
    /*
    * 第三步 如果要排序的话,首先是要选择是从小到大,还是从大到小来排序
    *
    * 在这里我们在上面已经选择了从小到大来排序
    * 第四步 首先,先找到三个函数指针中哪个是最小的数。其次,就是上面三个函数指针的返回值是不确定的,
    * 在不确定的前提下要找到最小的数,那么就需要 if 判断,来处理这种未知的情况。
    *
    */
    // 找到三个数中最小的数

          if(num1 < num2 && num1 < num3) {
                //如果这个判断成立那么 num1 可以确定是最小的数
                //那么接下来就需要写一个判断num2、num3,判断它们谁是第二个最小的数
                 if (num2 < num3) {
                    //这个判断是判断num2是否小于num3,如果num2 小于num3那么这个判断成立
                    //那么排序的顺序(从小到大)是 num1 num2 num3
                    //打印的话我们还是使用 alert() 来验证
    
                    alert('第一个最小数是:'+num1 +';第二个最小数是:'+num2+';第三个最小数是:'+num3);
                 } else{
                    //这个判断是判断num2是否小于num3,如果num2 不 小于num3那么这个判断成立
                    //那么排序的顺序(从小到大)是 num1 num3 num2
                    //打印的话我们还是使用 alert() 来验证
    
                    alert('第一个最小数是:'+num1 +';第二个最小数是:'+num3+';第三个最小数是:'+num2);
                 }
                 
            } else if(num2 < num1 && num2 < num3){
                //如果这个判断是成立的那么num2是最小的数
                //然后,在这里还需要写一个if判断,来比较num1和num3
                if (num1 < num3) {
                    //这里有点绕,在这个判断外面已经确定了num2是最小的数,那么接下来就是要确定num1、num3谁是第二个最小的数
                    //如果这个num1小于num3,那么排序的顺序(从小到大)是 num2 num1 num3
                    //打印的话我们还是使用 alert() 来验证
                    alert('第一个最小数是:'+num2 +';第二个最小数是:'+num1+';第三个最小数是:'+num3);
                    
                } else{
                    //这个判断是判断num1是否小于num3,如果num1 不 小于num3那么这个判断成立
                    //那么排序的顺序(从小到大)是 num2 num3 num1
                    //打印的话我们还是使用 alert() 来验证
                    alert('第一个最小数是:'+num2 +';第二个最小数是:'+num3+';第三个最小数是:'+num1);
                }
            } else{
                //如果上面两个判断都不成立,那num3是最小的数
                //确定num3之后,我们还需要确定num1和num2谁是第二个最小的数
                if (num1 < num2) {
                    //这里有点绕,在这个判断外面已经确定了num3是最小的数,那么接下来就是要确定num1、num2谁是第二个最小的数
                    //如果这个num1小于num3,那么排序的顺序(从小到大)是 num3 num1 num2
                    //打印的话我们还是使用 alert() 来验证
                    alert('第一个最小数是:'+num3 +';第二个最小数是:'+num1+';第三个最小数是:'+num2);
                    
                } else{
                    //这个判断是判断num1是否小于num2,如果num1 不 小于num2那么这个判断成立
                    //那么排序的顺序(从小到大)是 num3 num2 num1
                    //打印的话我们还是使用 alert() 来验证
                    alert('第一个最小数是:'+num3 +';第二个最小数是:'+num2+';第三个最小数是:'+num1);
                }
            }
    

    /*
    * 虽然这样写有点笨拙,代码也有点多,但是,他却把所有的可能性都写出来了,当然只有三个比较参数的话,
    * 只有这六个判断,比较参数再多一个的话可能就要再加几个判断了,这些都是废话
    *
    * 在以后的项目中 if 判断是经常被用到的,当然如果没有必要的话,可以不用写 if 判断,判断写多了会影响程序运行速度
    * 在项目里第一要有清晰的思路和逻辑。
    * 第二要有明确的目标。
    * 第三要有谨慎的态度
    * 这样才能搞成工作
    */

    快给朕打赏

    相关文章

      网友评论

        本文标题:JS基础 -- if 练习三

        本文链接:https://www.haomeiwen.com/subject/mhdwrftx.html