2017-01-07 120 views
0

所以,我有這個腳本什麼是應該從.txt文件中檢索一個值,每10秒更新一次。但是,根據計劃,.txt每10秒更改一次,但網站僅顯示1作爲我需要加載的值。Jquery.get只返回1

<!doctype html> 
<html> 
    <head> 
     <title>RNJESUS</title> 
     <link rel="icon" href="rnjesus.ico"> 
     <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> 
    </head> 

    <body background="rnjesus.jpg" style="background-size: 100%" text="white"> 
    <br><br><br><br><br><br><br><br><br><br><br> 
    <p align="center"> Üdvözlégy a félkész szerencsejáték szimulátorban. <br> 
        4 dologra lehet fogadni: 50 alatt, felett és ezen belül páros vagy páratlan.<br> 
        A Random Number Geisus (RNJézus) kisorsol neked egy számot 0 és 100 között. <br> 
        10 vagy az alatt, 90 vagy a felett, és kereken 50-nél a "ház" nyer. <br> 
        Jó játékot, és ne felejtkezz el imátkozzni RNJesushoz.<br> 
    </p> 

    <p align="center"> 
     Mennyivel akarsz beszállni?<br> 
     <input type="number" min="1" name="fogcredit"> 
     <button onclick="otvenalatt()">Fogadás: 50 alatt.</button> 
     <button onclick="otvenfelett()">Fogadás: 50 felett.</button> 
     <button id="start" onclick="bevitel()"> My body is ready </button> 
    </p> 
    <h1 align="center" id="warning"></h1> 
    <div align="center" id="creditcount"></div> 
    <div align="center" id="timer"></div> 
    <div align="center" id="szam"></div> 
    <div align="center" id="otven"></div> 
    <div align="center" id="paratlan"></div> 
    <h2 align="center" id="nyeremeny" ></h2> 


    <script src="jQuery.js"></script> 
    <script> 
    //<![CDATA[ 
     var frn 
     var otvenvar; 
     var nyeremenycredit; 
     var credit = 100 
     var otvenvar 
     var fogbevitel 
     var fogadas 
     var nyeremenycredit 
     var credit 
     var ido = 10 


     jQuery.get("szamok.txt", function(data){ 
      frn = data; 
     }); 



     function bevitel(){ 
     fogadas = document.getElementsByName("fogcredit")[0].value; 
     } 

     document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
     function otvenfelett(){ 
     otvenvar = 1; 
     } 
     function otvenalatt(){ 
     otvenvar = 0; 

     } 
     setInterval(function jesus(){ 
      if (credit > fogadas || credit == fogadas){ 
       document.getElementById('szam').innerHTML = ("Szám: " +frn); 
       credit = credit - fogadas; 
       nyeremenycredit = 0 
       document.getElementById("warning").innerHTML = (""); 

       if (frn < 11){ 
        document.getElementById('otven').innerHTML = ('The house always wins.'); 
        document.getElementById('paratlan').innerHTML = ("Mivel a ház nyert, nem számít hogy páros vagy pártalan."); 
        document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
        fogadas = 0 
       } 

       if (frn > 89){ 
        document.getElementById('otven').innerHTML = ("The house always wins."); 
        document.getElementById('paratlan').innerHTML = ("Mivel a ház nyert, nem számít hogy páros vagy pártalan."); 
        document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
        fogadas = 0 
       } 

       if (frn == 50){ 
        document.getElementById('otven').innerHTML = ("The house always wins."); 
        document.getElementById('paratlan').innerHTML = ("Mivel a ház nyert, nem számít hogy páros vagy pártalan."); 
        document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
        fogadas = 0 
       } 

       if (frn > 10 && frn < 50){ 
        document.getElementById('otven').innerHTML = ("50 alatt nyert."); 
        document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 

        if (otvenvar == 0){ 
         nyeremenycredit = fogadas * 2; 
         credit = credit + nyeremenycredit; 

         document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
        } 

        if (frn % 2 == 0){ 
         document.getElementById('paratlan').innerHTML = ('Páros szám nyert.'); 
         document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
         fogadas = 0 
        } 

        else{ 
         document.getElementById('paratlan').innerHTML = ('Páratlan szám nyert.'); 
         document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
         fogadas = 0 
        } 

       } 

       if (frn < 90 && frn > 50){ 
        document.getElementById('otven').innerHTML = ("50 felett nyert."); 
        if (otvenvar == 1){ 
         nyeremenycredit = fogadas * 2; 
         credit = credit + nyeremenycredit; 

         document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
        } 

        if (frn % 2 == 0){ 
         document.getElementById('paratlan').innerHTML = ("Páros szám nyert."); 
         document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
         fogadas = 0 
        } 

        else{ 
         document.getElementById('paratlan').innerHTML = ("Páratlan szám nyert."); 
         document.getElementById("creditcount").innerHTML = ("Jelenlegi krediteid:" + credit); 
         fogadas = 0 
        } 

       } 
      } 

      jQuery.get("szamok.txt", function(data){ 
       frn = data 
      }) 

      if (credit < fogadas){ 
      document.getElementById("warning").innerHTML = ("Nincs elég credit!"); 
      } 
     }, 10000); 

     setInterval(function(){ 
      if (ido > 0){ 
       ido = ido - 1; 
       document.getElementById("timer").innerHTML = ("Ennyi idő van hátra:" + ido); 
      } 
      if (ido === 0){ 
       document.getElementById("timer").innerHTML = ("Sorsolás megtörtént."); 
       ido = 10; 
      } 
     }, 1000); 
    //]]> 
</script> 
    </body> 
</html> 

整個代碼在上面。 我沒有在控制檯中的錯誤。 我在做什麼錯?

回答

0

我認爲這是因爲瀏覽器緩存HTTP請求並且不會向同一個URL發出GET請求。試試像這樣:

jQuery.get("szamok.txt?v=" + Math.random(), function(data){ 
    frn = data 
}); 
+0

最好增加一個計數器,而不是使用'Math.random()',因爲你運行的風險是與前一個請求的版本值相同。 – Prusprus

+0

非常感謝!我不會真正理解隨機數學在那裏做什麼,它應該是單獨的腳本中的服務器端,但令人驚訝的是,它的工作原理!你能解釋一下它在那裏做了什麼? –

+0

@CsabaKiss:瀏覽器緩存是通過URL進行的,所以更改URL會隨機停止緩存的響應被重用。不過,你的服務器應該發送一個'高速緩存控制',而不是使用'max-age'或'no-cache'。 – Ryan