0

ボタンをクリックしたときに aspx ファイルで CreateChart 関数を呼び出している特定の領域にフュージョン チャートを表示しようとしています。私が今持っている方法は、ページが読み込まれるとすぐにグラフが読み込まれるということですが、私が見たいのは、ボタンがクリックされたときにのみグラフが読み込まれることです。さまざまな方法を試しましたが、フュージョン チャートに慣れていないため、うまくいきませんでした。ありがとうこれが私のASPXファイルです:

<table class="style1">

<td class="style8">
                <asp:Button ID="btnClick" runat="server" Height="29px" Text="Button" 
                    Width="158px" onclick="btnClick_Click" />
            </td>

 <td class="style4" colspan="2">
               <% =CreateChart() %> </td>
        </tr>
    </table>

ここに私のコードビハインドがあります:

public string CreateChart()
    {
        SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString);
        string sqlStatement = "select   Status1, Count(Status1) as TotalCount from  MyTable where Closing_Date =  '" + txtStartClosingDate.Text + "' and Closing_Date <= '" + txtEndClosingDate.Text + "' and Status1 is not null group by  Status1";
        SqlCommand cmd = new SqlCommand(sqlStatement, con);
        con.Open();
        SqlDataReader reader = cmd.ExecuteReader();
        string strXML;
        strXML = "<graph labelDisplay='auto' useEllipsesWhenOverflow='1' decimals='2' decimalPrecision='0' showValues='1' enablesmartlabels='0' showlabels='0'  legendAllowDrag='1' numberSuffix=' Days' showLegend='1' pieSliceDepth='45' formatNumberScale='0'>";
        while (reader.Read())
        {
            strXML += "<set name='" + reader["Category"].ToString() + "' value='" + reader["AvgNumbers"].ToString() + "' />";
        }
        strXML += "</graph>";
        return FusionCharts.RenderChart("../FusionCharts/Pie2D.swf", "ChartID", strXML, "FactorySum", "450", "450", false, false);

    }
4

1 に答える 1

1

これを試して

それ以外の

<td class="style4" colspan="2">
           <% =CreateChart() %> </td>

使用する

<td class="style4" colspan="2">
           <asp:Literal mode="PassThrough" runat="server" ID="literalPlaceHolder"/> </td>

そしてボタンのイベントハンドラーで

public void btnClick_Click(...)
{
       literalPlaceHolder.Text = CreateChart();
}
于 2013-01-22T21:07:22.557 に答える