1

ここで何が間違っているのか正確にはわかりません。

部分ビューを返すアクションがあります:

public class SharedController : BaseController
{
public ActionResult StudentPoll()
        {
            WAM.X2O.FuelUpToPlayContext db = new WAM.X2O.FuelUpToPlayContext(WAM.Utilities.Config.ConnectionString);
            WAM.X2O.StudentPoll m = (from s in db.StudentPolls where s.IsActive == true select s).SingleOrDefault();

            return PartialView("StudentPoll", m);
        }
}

次のようにアクションを実装します。

<%Html.RenderAction("StudentPoll", "Shared");%>

部分ビューは次のようになります。

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl< Fuel_Up_To_Play.Models.Shared.StudentPollModel >" %>
<%if(ViewData.Model != null){ %>
<div class="block">
    <div class="holder">
        <div class="frame">
            <h2 class="poll">Student Poll</h2>
            <!-- TODO - Student Poll has a form screen, and results screen. 
                 Results anim is here to demo what should happen after submision -->
            <form action="/Shared/SubmitStudentPoll" method="post" class="poll-form" <%if(ViewData.Model.StartingState == Fuel_Up_To_Play.Models.Shared.StudentPollModel.PollStates.RESULTS){%>style="display:none"<%} %>>
                <fieldset>
                    <span><%=ViewData.Model.StudentPoll.Question %></span>
                    <input type="hidden" id="student_poll" name="student_poll" value="<%=ViewData.Model.StudentPoll.ID %>" />
                    <%foreach(WAM.X2O.StudentPollAnswer answer in ViewData.Model.StudentPoll.RelatedStudentPollAnswers){ %>
                    <div class="row">
                        <input type="radio" class="radio" id="answer_<%=answer.ID %>" name="poll_answer" value="<%=answer.ID %>"/>
                        <label for="answer_<%=answer.ID %>"><%=answer.AnswerText%></label>
                    </div>
                    <%} %>
                    <input id="submitBtn" type="image" style="display:none" class="image" src="/Content/images/btn-submit-05.gif" />
                </fieldset>
            </form>
            <div class="progress-box" <%if(ViewData.Model.StartingState == Fuel_Up_To_Play.Models.Shared.StudentPollModel.PollStates.FORM){%>style="display:none"<%} %>>
                <span><%=ViewData.Model.StudentPoll.Question %></span>
                <%int answerCounter = 0;
                foreach(WAM.X2O.StudentPollAnswer answer in ViewData.Model.StudentPoll.RelatedStudentPollAnswers){ %>
                <div class="box">
                    <span class="names"><%=answer.AnswerText%><strong class="quesPctTxt" rel="<%=ViewData.Model.AnswerPercentages[answerCounter] %>"></strong></span>
                    <div class="progress-bar"><span class="quesPctBar"></span></div>
                </div>
                <%
                    answerCounter++;
                } %>
            </div>
        </div>
    </div>
</div>
<script type="text/javascript" src="/Scripts/studentpollscript.js"></script>
<script type="text/javascript">

    $(document).ready(function() {

        $("input.radio[name='poll_answer']").change(function() {
            $("#submitBtn").show();
        });

        $("#submitBtn").click(function() {

            $(".poll-form").ajaxForm(
                { dataType: 'json',
                    success: function(json) {
                        alert(json.Success);

                    }
                }
            );

        });
    });

</script>

<%} %>

当然、このアプローチが HTML を返すことを期待しています。しかし、いいえ。代わりに、ブラウザでバイナリがレンダリングされているように見えます。明らかに私は何か間違ったことをしているのですが、私には何がわかりません。

ブラウザでレンダリングされるものは次のとおりです: http://screencast.com/t/Mjg1OWJj

アイデアはありますか?私は困惑していますが、私が見逃しているのは単純なものだと確信しています。

4

1 に答える 1

0

コンテンツタイプを正しく設定していないだけだと思います。ネットワーク トレース (フィドラーなど) は何を示していますか? View("StudentPoll", m);代わりにPartialView(...)?を使用してみてください。

また; 注意してください - それらの多くは<%=安全ではないように見えます。つまり、html エンコードされていません。

于 2010-07-30T20:51:57.020 に答える