2012-01-10 4 views
0

私は短いクイズでユーザーに提供するWebアプリケーションを開発しようとしています。私は、クイズエンジンについてのASP.NET Webサイトで説明されている例を追跡して利用しようとしています。私は結果ページにMaster-Detailsを持っています。ユーザーがGridViewで回答した質問の1つを選択すると、その質問の詳細がGridViewの下のDetailsViewに表示されます。すべてうまく動作します。マスター - ディテールGridViewとDetailsView?

答えたい質問の1つを選択しない限り、DetailsView(回答の質問の詳細)を非表示にするだけです。だからそれをどうやる?

また、このDetailsViewがPostBackの代わりにAjaxを使用して表示されると、非常に良いでしょう。

私のASP.NETコード:

<tr> 
       <td> 
        <asp:GridView ID="resultGrid" runat="server" DataKeyNames="QuestionID" SelectedIndex="0" 
        AutoGenerateColumns="False" CellPadding="4" ForeColor="#333333" GridLines="None" AutoGenerateSelectButton="True" OnSelectedIndexChanged="resultGrid_SelectedIndexChanged" Width="555px"> 
         <FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" /> 
         <RowStyle BackColor="#F7F6F3" ForeColor="#333333" CssClass="generaltext" HorizontalAlign="Center" /> 
         <Columns> 
          <asp:BoundField DataField="QuestionID" HeaderText="Question" /> 
          <%--<asp:BoundField DataField="CorrectAnswer" HeaderText="Correct Answer" />--%> 
          <asp:BoundField DataField="UserAnswer" HeaderText="Your Answer" /> 
          <asp:BoundField DataField="Result" HeaderText="Result" /> 
         </Columns> 
         <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" /> 
         <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" /> 
         <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" CssClass="boldtext" /> 
         <EditRowStyle BackColor="#999999" /> 
         <AlternatingRowStyle BackColor="White" ForeColor="#284775" /> 
        </asp:GridView> 

        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:testConnectionString %>" 
         SelectCommand="SELECT [Question], [Answer1], [Answer2], [Answer3], [QuestionID], [QuestionOrder], [Answer4], [CorrectAnswer], [AnswerExplanation], [QuizID] FROM [Question] WHERE ([QuizID] = @QuizID) ORDER BY [QuestionOrder]"> 
         <SelectParameters> 
          <asp:SessionParameter Name="QuizID" SessionField="QuizID" Type="Int32" /> 
         </SelectParameters> 
        </asp:SqlDataSource>     
       </td> 
      </tr> 
      <tr> 
       <td> 
        <asp:DetailsView ID="answerDetails" runat="server" CellPadding="4" ForeColor="#333333" 
         GridLines="None" Height="45px" Width="552px" DataSourceID="SqlDataSource1" 
         AutoGenerateRows="False" DataKeyNames="QuestionID"> 

         <FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" /> 
         <CommandRowStyle BackColor="#E2DED6" Font-Bold="True" /> 
         <RowStyle BackColor="#F7F6F3" ForeColor="#333333" CssClass="generaltext" /> 
         <FieldHeaderStyle BackColor="#E9ECF1" Font-Bold="True" CssClass="boldtext" Width="100px" /> 
         <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" /> 
         <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" /> 
         <EditRowStyle BackColor="#999999" /> 
         <AlternatingRowStyle BackColor="White" ForeColor="#284775" /> 
         <Fields> 
          <asp:BoundField DataField="Question" HeaderText="Question" 
           SortExpression="Question" /> 
          <asp:BoundField DataField="Answer1" HeaderText="A" 
           SortExpression="Answer1" /> 
          <asp:BoundField DataField="Answer2" HeaderText="B" 
           SortExpression="Answer2" /> 
          <asp:BoundField DataField="Answer3" HeaderText="C" 
           SortExpression="Answer3" /> 
          <asp:BoundField DataField="Answer4" HeaderText="D" 
           SortExpression="Answer4" /> 
          <asp:BoundField DataField="CorrectAnswer" HeaderText="Correct Answer" 
           SortExpression="CorrectAnswer" HeaderStyle-BackColor="lightgreen" /> 
          <asp:BoundField DataField="AnswerExplanation" HeaderText="Explanation" 
           SortExpression="AnswerExplanation" HeaderStyle-BackColor="lightgreen" /> 
         </Fields> 
        </asp:DetailsView>     
       </td> 
      </tr> 

EDIT:

enter image description here

コードビハインド私が持っているということは、次のとおりです。

protected void Page_Load(object sender, EventArgs e) 
    { 
     ArrayList al = (ArrayList)Session["AnswerList"]; 

     if (al == null) 
     { 
      Response.Redirect("default.aspx"); 
     } 

     resultGrid.DataSource = al; 
     resultGrid.DataBind(); 

     // Save the results into the database. 
     if (IsPostBack == false) 
     { 
      // Calculate score 
      double questions = al.Count; 
      double correct = 0.0; 


      for (int i = 0; i < al.Count; i++) 
      { 
       Answer a = (Answer)al[i]; 
       if (a.Result == Answer.ResultValue.Correct) 
        correct++; 
      } 

      double score = (correct/questions) * 100; 
      string username = HttpContext.Current.User.Identity.Name.ToString().Replace("ARAMCO\\", ""); 
      SqlDataSource userQuizDataSource = new SqlDataSource(); 
      userQuizDataSource.ConnectionString = ConfigurationManager.ConnectionStrings["testConnectionString"].ToString(); 
      userQuizDataSource.InsertCommand = "INSERT INTO [UserQuiz] ([QuizID], [DateTimeComplete], [Score], [Username]) VALUES (@QuizID, @DateTimeComplete, @Score, @Username)"; 

      userQuizDataSource.InsertParameters.Add("QuizID", Session["QuizID"].ToString()); 
      userQuizDataSource.InsertParameters.Add("DateTimeComplete", DateTime.Now.ToString()); 

      // "N4" is for displaying four decimal places, regardless of what the value is 
      userQuizDataSource.InsertParameters.Add("Score", score.ToString("N4")); 

      userQuizDataSource.InsertParameters.Add("Username", username); 

      int rowsAffected = userQuizDataSource.Insert(); 
      if (rowsAffected == 0) 
      { 
       // Let's just notify that the insertion didn't 
       // work, but let' s continue on ... 
       errorLabel.Text = "There was a problem saving your quiz results into our database. Therefore, the results from this quiz will not be displayed on the list on the main menu."; 


      } 

     } 


    } 

答えて

0

私はすべてのあなただと思いますパラメタを取るためにSqlDataSource1をinorderで更新する必要がありますユーザーがGridViewで行を選択しない限り、DetailsViewは表示されません。これを試して。

<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString=" 
    <%$ConnectionStrings:testConnectionString %>" 
    SelectCommand="SELECT [Question], [Answer1], [Answer2], [Answer3], [QuestionID], 
    [QuestionOrder], [Answer4], [CorrectAnswer], [AnswerExplanation], [QuizID] FROM 
    [Question] WHERE ([QuestionID] = @QuestionID) ORDER BY [QuestionOrder]"> 
        <SelectParameters> 
         <asp:ControlParameter ControlID="resultGrid" Name="QuestionID" 
         PropertyName="SelectedValue" Type="Int32" /> 
        </SelectParameters> 
</asp:SqlDataSource> 

私はそれはあなたの問題あなたの助けのための

+0

感謝を解決することを願っています。私はあなたが私にそれを与えたことを試みたが、それは私と一緒に働いた。 DetailsViewは表示されなくなりましたが、回答した質問のほかにselectをクリックすると何も表示されませんでした。私が望むのは、SelectをクリックしたときにDetailsViewを表示することです。どうやってするか? – user1093651

+0

正確には、gridViewの行を選択するときに私が示唆したものです。上記のselectコマンドを編集した方法を見たことがありますか?WHERE([QuestionID] = @QuestionID) "そのままコードをコピーして試してみてください。これは、resulGridのDataKeyNames = "QuestionID"まで機能するはずです – Mubarek

+0

ところで、使用している選択ボタンをチェックしてください。可能であれば投稿する – Mubarek

関連する問題