2014-10-29 50 views
0

我正在處理一個網頁,該網頁可以提取用戶分數並將分數提高到一個百分比。然後使用百分比使用width和aria-valuenow來填充Bootstrap進度條。ASPX頁面上的C#值在刷新時結合在一起

問題是,在初始構建和頁面刷新後,進度條寬度(又稱分數)隨原始分數增加。例如,如果百分比從40開始,它將刷新爲80 ... 120 ... 160 ...等。

下面是C#代碼,我分配的值:例如起見

private static string[][] matches = new string[numOfGames][]; 
private static string[] winningTeams = new string[numOfGames]; 
protected static string[,] players = { { "Name", "0" }, { "Name", "0" }, { "Name", "0" }, { "Name", "0" }, { "Name", "0" }, { "Name", "0" }, { "Name", "0" }, { "Name", "0" }, { "Name", "0" } }; 
public static double score_name1, score_name2, score_name3, score_name4, score_name5, score_name6, score_name7, score_name8, score_name9; 

protected void Page_Load(object sender, EventArgs e) { 
    gatherMatches(); 

    DataTable userPicks = getGSheetData(); 
    userPicks.Columns.Remove("Timestamp"); 
    userPicks.Columns.Remove("Your Name"); 

    convertTeamNames(); 

    compareMatches(); 

    generateUserScores(userPicks); 

    score_name1 = Convert.ToDouble(players[0, 1])/numOfGames * 100.00; 
    score_name2 = Convert.ToDouble(players[1, 1])/numOfGames * 100.00; 
    score_name3 = Convert.ToDouble(players[2, 1])/numOfGames * 100.00; 
    score_name4 = Convert.ToDouble(players[3, 1])/numOfGames * 100.00; 
    score_name5 = Convert.ToDouble(players[4, 1])/numOfGames * 100.00; 
    score_name6 = Convert.ToDouble(players[5, 1])/numOfGames * 100.00; 
    score_name7 = Convert.ToDouble(players[6, 1])/numOfGames * 100.00; 
    score_name8 = Convert.ToDouble(players[7, 1])/numOfGames * 100.00; 
    score_name9 = Convert.ToDouble(players[8, 1])/numOfGames * 100.00; 

    name2.Attributes.Add("style", "width: " + score_name2.ToString() + "%"); 
    name2.Attributes.Add("aria-valuenow", players[0, 1].ToString()); 
} 

代替實際名稱的值。

而在ASPX頁面:

<%@ Page Title="Scoreboard" Language="C#" MasterPageFile="~/Site.Master" AutoEventWireup="true" CodeBehind="Scoreboard.aspx.cs" Inherits="Football.Scoreboard" %> 

<asp:Content ID="BodyContent" ContentPlaceHolderID="MainContent" runat="server"> 
<div class="page-header"> 
    <h2><%: Title %></h2> 
    <h3>See up to date standings.</h3> 
</div> 
<p>This page can be refreshed during game time to see changes in leaders as they happen.</p> 
<div class="row"> 
    <div class="col-md-6"> 
     <h3>This Week</h3> 
     <div class="progress"> 
      <div id="name1" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="5" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Name 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name2" runat="server" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="16"> 
       Name 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name3" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="4" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Name 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name4" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="3" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Jen 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name5" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="1" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Name 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name6" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Name 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name7" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Ryan 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name8" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Name 
      </div> 
     </div> 
     <div class="progress"> 
      <div id="name9" class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="16" style="width: 0%"> 
       Name 
      </div> 
     </div> 
    </div> 

我只應用了行動,第二個進度條,因爲別人在目前沒有數據。

+0

提供了更多關於該頁面的代碼......沒有足夠的信息來推斷該問題。 – scartag 2014-10-29 06:01:27

+0

你是指aspx頁面還是cs頁面? – lostchopstik 2014-10-29 06:11:04

回答

0

那麼我確實找出瞭解決方案。出於某種原因,二維數組的值在每次刷新時都保持不變,所以當我調用gatherUserScores(userPicks)時,它會將當前的分數加到舊的分數上,從而增加原來的分數。

for (int i = 0; i < players.Length/2; i++) 
     { 
      players[i, 1] = "0"; 
     } 

我發現的值被持續可通過檢測當頁面被刷新,而不是重新運行該代碼可以預防的原因:

我每次解決了這個通過將下面的循環到陣列復位,但是即使我發現了一些例子,我也沒有運氣,所以這種方法效果最好。

感謝您的幫助球員。

0

我推斷你的問題很多,但在你的代碼中考慮這兩個因素。

在你Page_Laod代碼,你可能需要使用該頁面功能的IsPostBack() 如果(!的IsPostBack){ // 做的工作,你只在第一次加載做 //設置進度0和init變量0 } 其他 {// 添加或做這個頁面加載的數學只 }

現在也消除您的靜態數學和頁面變量。

另請參見: 您的第二個進度欄在它的html中沒有將百分比設置爲0來啓動。

查看您的呈現的html源代碼,當它第一次加載和失敗時。這將爲您提供有關您遇到問題的線索。

編輯:

靜態變量 - 我想看看如果你是從你的靜態變量中的一個讀取值。儘量不要使用你創建的靜態變量。嘗試從getGSheetdata()獲取所有當前數據。另一種說法是,你不應該在Page_Load函數上面聲明變量。所有值都應從每個頁面開始新增,例如0. (在此特定情況下)您的下一步應該是在數據更改點上設置一箇中斷點,並觀察代碼每一步的值。

+0

我試圖使用IsPostBack方法,但它不檢測使用瀏覽器的刷新按鈕,只有手動添加到頁面的刷新按鈕。 你究竟是指什麼靜態數學? – lostchopstik 2014-10-29 06:44:52

+0

另外,這裏是源之前: '

Reese
'後:'
Reese
' – lostchopstik 2014-10-29 06:55:35

相關問題