2016-08-06 85 views
-1

我想讓它在哪裏,如果你點擊按鈕,那麼bestPlayer.available變成false,並且pick = true。屏幕會顯示名稱,但是一旦你點擊按鈕選擇最上面的那個,它就會消失,並且一個新的應該進入列表(列表中有七個玩家)。這是我嘗試的代碼。請幫忙!Javascript按鈕連接

<!DOCTYPE html> 
<html> 
    <head> 
     <title>The Draft</title> 
     <link rel="stylesheet" type="text/css" href="Draft Stylesheet.css"/> 
    </head> 

    <body> 
     <div> 
      <table id="players"> 
       <thead> 
        <tr> 
         <th id="rtgH">RTG</th> 
         <th id="nameH">Player Name</th> 
         <th id="ovrH">OVR</th> 
         <th id="posH">POS</th> 
         <th id="choose">Draft</th> 
        </tr> 
       <tbody> 
        <tr> 
         <td>1</td> 
         <td id="p1">Player</td> 
         <td id="p1ovr">99</td> 
         <td id="p1pos">PO</td> 
         <td> <input type="button" onclick="bestPlayer.available = false; picked=true;" value = "draft"> </td> 
        </tr> 
        <tr> 
         <td>2</td> 
         <td id="p2">Player</td> 
         <td id="p2ovr">99</td> 
         <td id="p2pos">PO</td> 
        </tr> 
        <tr> 
         <td>3</td> 
         <td id="p3">Player</td> 
         <td id="p3ovr">99</td> 
         <td id="p3pos">PO</td> 
        </tr> 
        <tr> 
         <td>4</td> 
         <td id="p4">Player</td> 
         <td id="p4ovr">99</td> 
         <td id="p4pos">PO</td> 
        </tr> 
        <tr> 
         <td>5</td> 
         <td id="p5">Player</td> 
         <td id="p5ovr">99</td> 
         <td id="p5pos">PO</td> 
        </tr> 
        <tr> 
         <td>6</td> 
         <td id="p6">Player</td> 
         <td id="p6ovr">99</td> 
         <td id="p6pos">PO</td> 
        </tr> 
        <tr> 
         <td>7</td> 
         <td id="p7">Player</td> 
         <td id="p7ovr">99</td> 
         <td id="p7pos">PO</td> 
        </tr> 
       </tbody> 
       </thead> 
      </table> 
     </div> 
     <script> 
      var picked = false; 
      var round = 1; 
      var pick = 1; 
      var first = true; 
      function comp(b, a) { 
      return a.overall - b.overall; 
      } 
      var players = [{ 
       name: "Pat Moran", 
       overall: 67, 
       position: "AP", 
       available: true 
      }, { 
       name: "Peter Webb", 
       overall: 81, 
       position: "AP", 
       available: true 
      }, { 
       name: "Ramiro Ramirez", 
       overall: 74, 
       position: "AP", 
       available: true 
      }, { 
       name: "Manuel Knight", 
       overall: 68, 
       position: "RP", 
       available: true 
      }, { 
       name: "Allan Alexander", 
       overall: 71, 
       position: "RP", 
       available: true 
      }, { 
       name: "Gerald Bowman", 
       overall: 81, 
       position: "RP", 
       available: false 
      }, { 
       name: "Owen Day", 
       overall: 78, 
       position: 3, 
       available: true 
      }, { 
       name: "Jean Ford", 
       overall: 70, 
       position: 3, 
       available: false 
      }, { 
       name: "Guy Curtis", 
       overall: 59, 
       position: 3, 
       available: true 
      }, { 
       name: "Dallas Diaz", 
       overall: 68, 
       position: 4, 
       available: false 
      }, { 
       name: "Jesus Brooks", 
       overall: 70, 
       position: 4, 
       available: true 
      }, { 
       name: "Todd Beck", 
       overall: 76, 
       position: 4, 
       available: false 
      }, { 
       name: "Steve Cortez", 
       overall: 66, 
       position: 5, 
       available: true 
      }, { 
       name: "Toby Caldwell", 
       overall: 64, 
       position: 5, 
       available: false 
      }, { 
       name: "Seth Bradley", 
       overall: 73, 
       position: 5, 
       available: true 
      }, { 
       name: "Lawrence McCarthy", 
       overall: 67, 
       position: 6, 
       available: false 
      }, { 
       name: "Gerardo Marsh", 
       overall: 77, 
       position: 6, 
       available: true 
      }, { 
       name: "Alvin Nash", 
       overall: 78, 
       position: 6, 
       available: false 
      }]; 

      function checkAvailabilty(obj) { 
       return !!obj.available; 
      } 

      var findBestPlayer = (function(arr) { 
       // a copy of the original data is made. 
       var data = arr.slice(0); 
       // sort the data with a comparator function 
       data.sort(comp); 
       // filter out the unavailable players. 
       data = data.filter(checkAvailabilty); 
       return function(index) { 
       return data[index]; 
       } 
      })(players); 

      if(picked === true || first === true) { 
       bestPlayer = findBestPlayer(0); 
       bestPlayerTwo = findBestPlayer(1); 
       bestPlayerThree = findBestPlayer(2); 
       bestPlayerFour = findBestPlayer(3); 
       bestPlayerFive = findBestPlayer(4); 
       bestPlayerSix = findBestPlayer(5); 
       bestPlayerSeven = findBestPlayer(6); 
       first = false; 
       picked = false; 
      } 

      document.getElementById("p1").innerHTML = bestPlayer.name; 
      document.getElementById("p1ovr").innerHTML = bestPlayer.overall; 
      document.getElementById("p1pos").innerHTML = bestPlayer.position; 
      document.getElementById("p2").innerHTML = bestPlayerTwo.name; 
      document.getElementById("p2ovr").innerHTML = bestPlayerTwo.overall; 
      document.getElementById("p2pos").innerHTML = bestPlayerTwo.position; 
      document.getElementById("p3").innerHTML = bestPlayerThree.name; 
      document.getElementById("p3ovr").innerHTML = bestPlayerThree.overall; 
      document.getElementById("p3pos").innerHTML = bestPlayerThree.position; 
      document.getElementById("p4").innerHTML = bestPlayerFour.name; 
      document.getElementById("p4ovr").innerHTML = bestPlayerFour.overall; 
      document.getElementById("p4pos").innerHTML = bestPlayerFour.position; 
      document.getElementById("p5").innerHTML = bestPlayerFive.name; 
      document.getElementById("p5ovr").innerHTML = bestPlayerFive.overall; 
      document.getElementById("p5pos").innerHTML = bestPlayerFive.position; 
      document.getElementById("p6").innerHTML = bestPlayerSix.name; 
      document.getElementById("p6ovr").innerHTML = bestPlayerSix.overall; 
      document.getElementById("p6pos").innerHTML = bestPlayerSix.position; 
      document.getElementById("p7").innerHTML = bestPlayerSeven.name; 
      document.getElementById("p7ovr").innerHTML = bestPlayerSeven.overall; 
      document.getElementById("p7pos").innerHTML = bestPlayerSeven.position; 
     </script> 
    </body> 
</html> 
+0

我不知道什麼是錯的。當我點擊草稿按鈕時,沒有任何反應。控制檯中也沒有錯誤。 –

+0

您能否將此代碼轉換爲jsfiddle來幫助我們幫助您? – JBartus

回答

0

你必須明白,JavaScript代碼只能在頁面加載時運行一次,除非你調用它。
因此,您只需將用於設置表值的代碼移動到函數中並觸發onClick即可。

<!DOCTYPE html> 
 
<html> 
 
    <head> 
 
     <title>The Draft</title> 
 
     <link rel="stylesheet" type="text/css" href="Draft Stylesheet.css"/> 
 
    </head> 
 

 
    <body> 
 
     <div> 
 
      <table id="players"> 
 
       <thead> 
 
        <tr> 
 
         <th id="rtgH">RTG</th> 
 
         <th id="nameH">Player Name</th> 
 
         <th id="ovrH">OVR</th> 
 
         <th id="posH">POS</th> 
 
         <th id="choose">Draft</th> 
 
        </tr> 
 
       <tbody> 
 
        <tr> 
 
         <td>1</td> 
 
         <td id="p1">Player</td> 
 
         <td id="p1ovr">99</td> 
 
         <td id="p1pos">PO</td> 
 
         <td> <input type="button" onclick="bestPlayer.available = false; picked=true;refresh();" value = "draft"> </td> 
 
        </tr> 
 
        <tr> 
 
         <td>2</td> 
 
         <td id="p2">Player</td> 
 
         <td id="p2ovr">99</td> 
 
         <td id="p2pos">PO</td> 
 
        </tr> 
 
        <tr> 
 
         <td>3</td> 
 
         <td id="p3">Player</td> 
 
         <td id="p3ovr">99</td> 
 
         <td id="p3pos">PO</td> 
 
        </tr> 
 
        <tr> 
 
         <td>4</td> 
 
         <td id="p4">Player</td> 
 
         <td id="p4ovr">99</td> 
 
         <td id="p4pos">PO</td> 
 
        </tr> 
 
        <tr> 
 
         <td>5</td> 
 
         <td id="p5">Player</td> 
 
         <td id="p5ovr">99</td> 
 
         <td id="p5pos">PO</td> 
 
        </tr> 
 
        <tr> 
 
         <td>6</td> 
 
         <td id="p6">Player</td> 
 
         <td id="p6ovr">99</td> 
 
         <td id="p6pos">PO</td> 
 
        </tr> 
 
        <tr> 
 
         <td>7</td> 
 
         <td id="p7">Player</td> 
 
         <td id="p7ovr">99</td> 
 
         <td id="p7pos">PO</td> 
 
        </tr> 
 
       </tbody> 
 
       </thead> 
 
      </table> 
 
     </div> 
 
     <script> 
 
\t \t 
 
      var picked = false; 
 
      var round = 1; 
 
      var pick = 1; 
 
      var first = true; 
 
      function comp(b, a) { 
 
      return a.overall - b.overall; 
 
      } 
 
      var players = [{ 
 
       name: "Pat Moran", 
 
       overall: 67, 
 
       position: "AP", 
 
       available: true 
 
      }, { 
 
       name: "Peter Webb", 
 
       overall: 81, 
 
       position: "AP", 
 
       available: true 
 
      }, { 
 
       name: "Ramiro Ramirez", 
 
       overall: 74, 
 
       position: "AP", 
 
       available: true 
 
      }, { 
 
       name: "Manuel Knight", 
 
       overall: 68, 
 
       position: "RP", 
 
       available: true 
 
      }, { 
 
       name: "Allan Alexander", 
 
       overall: 71, 
 
       position: "RP", 
 
       available: true 
 
      }, { 
 
       name: "Gerald Bowman", 
 
       overall: 81, 
 
       position: "RP", 
 
       available: false 
 
      }, { 
 
       name: "Owen Day", 
 
       overall: 78, 
 
       position: 3, 
 
       available: true 
 
      }, { 
 
       name: "Jean Ford", 
 
       overall: 70, 
 
       position: 3, 
 
       available: false 
 
      }, { 
 
       name: "Guy Curtis", 
 
       overall: 59, 
 
       position: 3, 
 
       available: true 
 
      }, { 
 
       name: "Dallas Diaz", 
 
       overall: 68, 
 
       position: 4, 
 
       available: false 
 
      }, { 
 
       name: "Jesus Brooks", 
 
       overall: 70, 
 
       position: 4, 
 
       available: true 
 
      }, { 
 
       name: "Todd Beck", 
 
       overall: 76, 
 
       position: 4, 
 
       available: false 
 
      }, { 
 
       name: "Steve Cortez", 
 
       overall: 66, 
 
       position: 5, 
 
       available: true 
 
      }, { 
 
       name: "Toby Caldwell", 
 
       overall: 64, 
 
       position: 5, 
 
       available: false 
 
      }, { 
 
       name: "Seth Bradley", 
 
       overall: 73, 
 
       position: 5, 
 
       available: true 
 
      }, { 
 
       name: "Lawrence McCarthy", 
 
       overall: 67, 
 
       position: 6, 
 
       available: false 
 
      }, { 
 
       name: "Gerardo Marsh", 
 
       overall: 77, 
 
       position: 6, 
 
       available: true 
 
      }, { 
 
       name: "Alvin Nash", 
 
       overall: 78, 
 
       position: 6, 
 
       available: false 
 
      }]; 
 

 
      function checkAvailabilty(obj) { 
 
       return !!obj.available; 
 
      } 
 

 
      
 

 
\t \t \t function refresh() 
 
\t \t { 
 
\t \t var findBestPlayer = (function(arr) { 
 
       // a copy of the original data is made. 
 
       var data = arr.slice(0); 
 
       // sort the data with a comparator function 
 
       data.sort(comp); 
 
       // filter out the unavailable players. 
 
       data = data.filter(checkAvailabilty); 
 
       return function(index) { 
 
       return data[index]; 
 
       } 
 
      })(players); 
 
\t \t \t 
 
      if(picked === true || first === true) { 
 
       bestPlayer = findBestPlayer(0); 
 
       bestPlayerTwo = findBestPlayer(1); 
 
       bestPlayerThree = findBestPlayer(2); 
 
       bestPlayerFour = findBestPlayer(3); 
 
       bestPlayerFive = findBestPlayer(4); 
 
       bestPlayerSix = findBestPlayer(5); 
 
       bestPlayerSeven = findBestPlayer(6); 
 
       first = false; 
 
       picked = false; 
 
      } 
 

 
      document.getElementById("p1").innerHTML = bestPlayer.name; 
 
      document.getElementById("p1ovr").innerHTML = bestPlayer.overall; 
 
      document.getElementById("p1pos").innerHTML = bestPlayer.position; 
 
      document.getElementById("p2").innerHTML = bestPlayerTwo.name; 
 
      document.getElementById("p2ovr").innerHTML = bestPlayerTwo.overall; 
 
      document.getElementById("p2pos").innerHTML = bestPlayerTwo.position; 
 
      document.getElementById("p3").innerHTML = bestPlayerThree.name; 
 
      document.getElementById("p3ovr").innerHTML = bestPlayerThree.overall; 
 
      document.getElementById("p3pos").innerHTML = bestPlayerThree.position; 
 
      document.getElementById("p4").innerHTML = bestPlayerFour.name; 
 
      document.getElementById("p4ovr").innerHTML = bestPlayerFour.overall; 
 
      document.getElementById("p4pos").innerHTML = bestPlayerFour.position; 
 
      document.getElementById("p5").innerHTML = bestPlayerFive.name; 
 
      document.getElementById("p5ovr").innerHTML = bestPlayerFive.overall; 
 
      document.getElementById("p5pos").innerHTML = bestPlayerFive.position; 
 
      document.getElementById("p6").innerHTML = bestPlayerSix.name; 
 
      document.getElementById("p6ovr").innerHTML = bestPlayerSix.overall; 
 
      document.getElementById("p6pos").innerHTML = bestPlayerSix.position; 
 
      document.getElementById("p7").innerHTML = bestPlayerSeven.name; 
 
      document.getElementById("p7ovr").innerHTML = bestPlayerSeven.overall; 
 
      document.getElementById("p7pos").innerHTML = bestPlayerSeven.position; 
 
\t \t \t } 
 
\t \t \t refresh(); 
 
     </script> 
 
    </body> 
 
</html>

+0

我剛剛意識到這不適合關係。你認爲你可以編輯它,所以這是兩個球員並列,他們都會一個接一個地出現嗎? –

+0

@DallasWhite seriouly?你不知道這個概念......我幫助過它......我沒有幫你用這麼瑣碎的邏輯......自己弄清楚......這將有助於長跑 –