溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JS+PHP如何實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置

發(fā)布時間:2021-06-22 14:42:42 來源:億速云 閱讀:198 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要為大家展示了“JS+PHP如何實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“JS+PHP如何實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置”這篇文章吧。

本文主要給大家介紹的是關(guān)于JS+PHP實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置的相關(guān)內(nèi)容,目的:分清JS PHP的區(qū)別,拓寬思維,下面來一起看看詳細(xì)的介紹:

分析

       1.利用JS的prompt輸入用戶想要輸入的值.

       2.利用HTML表單的text標(biāo)簽將輸入的值傳遞給PHP處理文件

       3.PHP進(jìn)行數(shù)值判定,選出最大值和位置.

由淺入深:

1.在JS實現(xiàn)獲取數(shù)組的最大值.

var a=[10,20,40,30];
 // var max=0;
 var max=a[0];
 for(var i=0;i<a.length;i++){
 if(max<a[i]){
  max=a[i];
 }
 }
 alert("最大數(shù)為"+max);

這里值得注意的是:不可以直接設(shè)置一個變量max=0,因為你不確定以后輸入的數(shù)字是小于0的還是大于0的[案列是大于0的],所以應(yīng)該選擇數(shù)組里面的一個數(shù),就數(shù)組的第一個好了max=a[0] .

因為JS語言是基于對象面向過程的,JS里面所有的事物都可以是對象,所以它的數(shù)組有屬性,length就是JS數(shù)組的一個獲得數(shù)組長度的屬性,有了這個屬性就可以遍歷數(shù)組,然后進(jìn)行一一比較.

2.在JS實現(xiàn)獲得數(shù)組的最大值最小值和他們的位置(即在數(shù)組中第幾個)

[注:本案例位置+1是為了方便查看,JS數(shù)組開始也是0]

var a=[10,20,40,30];
 var max=a[0];//不能指定一個數(shù)為最大值[var max=0](除非是確定的情況下),應(yīng)該用數(shù)組里面的值,a[0]即讓數(shù)組第一個值作為比較的最大值.
 var maxaddress=0;
 var min=a[0];
 var minaddress=0;
 for(var i=0;i<a.length;i++){
  if(max<a[i]){
   max=a[i];
   maxaddress=i
  }
  if(min>a[i]){
   min=a[i];
   minaddress=i
  }
 }
 alert("最大數(shù)為"+max+"位置為第"+(maxaddress+1)+"個");
 alert("最小數(shù)為"+min+"位置為第"+(minaddress+1)+"個");

3.現(xiàn)在改成用prompt來進(jìn)行用戶輸入獲得值來求最大值等等.

難點(diǎn):

       1.如何輸入,用prompt

       2.如何將一個字符串轉(zhuǎn)為數(shù)組,并且要轉(zhuǎn)換格式呢?

前提知識:

       1.將字符串分割 用到的是JS的string對象的spilt方法(注意,JS一切皆是對象,因此叫方法,不叫函數(shù))

       2.讓一個"abc"字符串轉(zhuǎn)為number類型,怎么轉(zhuǎn).

字符串轉(zhuǎn)數(shù)字類型

◆Number

★數(shù)字類型的字符串,轉(zhuǎn)換之后得到的數(shù)字。var n1="123"; var n2=Number(n1);//123

★★非數(shù)字字符串,轉(zhuǎn)換之后得到是NaN。var n1="123abc"; var n2=Number(n1);//Nan 

★小數(shù)類型的字符串,轉(zhuǎn)換之后得到的是原數(shù)字。var n1="123.23"; var n2=Number(n1);//123.23

 

◆parseInt

★整數(shù)數(shù)字類型的字符串,轉(zhuǎn)換之后得到的整數(shù)數(shù)字。var n1="123"; var n2=parseInt(n1);//123

★數(shù)字開頭的字符串,轉(zhuǎn)換之后得到的是前邊的數(shù)字。var n1="123abc"; var n2=parseInt(n1);//123

★非數(shù)字開頭的字符串,轉(zhuǎn)換之后得到的是NaN。。var n1="abc123"; var n2=parseInt(n1);//NaN

★★小數(shù)類型的字符串,轉(zhuǎn)換之后取整(小數(shù)點(diǎn)直接省略)。var n1="123.53"; var n2=parseInt(n1);//123 var n1="-5.93"; var n2=parseInt(n1);//-5

 

◆parseFloat

★整數(shù)數(shù)字類型的字符串,轉(zhuǎn)換之后得到的整數(shù)數(shù)字。var n1="123"; var n2=parseFloat(n1);//123

★數(shù)字開頭的字符串,轉(zhuǎn)換之后得到的是前邊的數(shù)字。var n1="123abc"; var n2=parseFloat(n1);//123

★非數(shù)字開頭的字符串,轉(zhuǎn)換之后得到的是NaN。var n1="abc123"; var n2=parseFloat(n1);//NaN

★★小數(shù)類型的字符串,轉(zhuǎn)換之后得到的是原數(shù)字。var n1="123.23"; var n2=parseFloat(n1);//123.23

 

轉(zhuǎn)布爾類型

★數(shù)字和字符串轉(zhuǎn)完之后為true。

★undefined、null、0轉(zhuǎn)完之后為false.

var n1=123; var n2=Boolean(n1);//true

var n1="123"; var n2=Boolean(n1);//true

var n1="0"; var n2=Boolean(n1);alert(n2);//true

var n1; var n2=Boolean(n1);//false

var n1=null; var n2=Boolean(n1);//false

var n1=0; var n2=Boolean(n1);//false

以上分析完畢,開始書寫代碼

<script>
  //var a=new Array(-12,34,56,88,32,"aa","-34.33","-34.34",12.23);
  /*var a=new Array(prompt("請輸入數(shù)字"));
  document.write(a);*/
  var b=prompt("請輸入要比較的數(shù),用\",\"號隔開");
  var a=new Array();
  a=b.split(",");
  // for(var j=0;j<a.length;j++){
  //   document.write(a[j]);
  // }
  alert(typeof(a)+" JS數(shù)組本質(zhì)是對象啊!!");//本質(zhì)是對象 PHP數(shù)組就是數(shù)組,沒有屬性(比如length)
  document.write(a+"<br>");
  console.log(a+"<br>");
  var max=parseFloat(a[0]);
  //document.write(max);
  var maxaddress=0;
  var min=parseFloat(a[0]);
  var minaddress=0;
  
  for(var i=0;i<=a.length;i++){
   var shu=parseFloat(a[i]);
   if(shu>max){
    max=shu;
    maxaddress=i;
   }
   if(shu<min){
    min=a[i];
    minaddress=i;
   }
  }
  document.write("最大數(shù)為"+max+"位置為第"+(maxaddress+1)+"個"+"<br>");
  document.write("最小數(shù)為"+min+"位置為第"+(minaddress+1)+"個");
 </script>

4.以上是JS做處理,我的目的是讓JS+PHP+HTML聯(lián)動起來.

PHP是無法直接前端交互的,即他不能直接獲取用戶輸入的值,而要通過html 的form表單

JS數(shù)據(jù)傳給PHP,你可以用AJAX,但我以后再講,今天看看有什么方法.

1.制作HTML表單:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 
</head>
<body>
 <form action="deal.php" method="post">
 請輸入數(shù)字:<input type="text" id="shu" name="shuzi" value="">
 <input type="submit" value="提交">
 </form>
 
</body>
</html>

2.JS傳值給HTML:

 <script type="text/javascript">
  var a=prompt("請輸入數(shù)字");
  document.getElementById("shu").value=a;
 </script>

這里有個坑,如果將JS代碼寫在HTML的header處,會報錯,說Uncaught TypeError: Cannot set property 'value' of null

因為瀏覽器解析順序,在瀏覽器解析JS的時候(輸入數(shù)字完成的時候),瀏覽器開始解析HTML,雖然JS賦值了text的value,但被后面HTML的解析成了text的value為NULL,這是自相矛盾的.

所以盡可能的讓JS代碼寫在后面,你先解析HTML,然后我再給你值.(具體情況具體分析,不一定JS代碼都在頭部)

5.好了,HTML傳值了,現(xiàn)在看PHP

<?php
header("Content-type:text/html;charset=utf-8");
$a=$_POST['shuzi'];
//var_dump($a);
$b=explode(',',$a);
for($i=0;$i<count($b);$i++){
 echo $b[$i];
}
var_dump($b);

$max=$b[0];
$maxaddress=0;
for($j=0;$j<count($b);$j++){
 if($b[$j]>$max){
  $max=$b[$j];
  $maxaddress=$j;
 }

}
echo "最大值是".$max."<br>";
echo "位置為第".($maxaddress+1)."個";


?>

這里主要是看explode(將字符串拆分成數(shù)組) count(獲得數(shù)組的個數(shù))

還有注意類型轉(zhuǎn)換問題,以后補(bǔ)充或者你自己寫寫吧.

最后上圖:

JS+PHP如何實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置

JS+PHP如何實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置

JS+PHP如何實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置

以上是“JS+PHP如何實現(xiàn)用戶輸入數(shù)字后顯示最大的值及所在位置”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI