ASP.NET在母版页上使用SqlDatasource

时间:2014-01-03 17:05:26

标签: c# asp.net master-pages sqldatasource

我正在尝试根据当前用户的角色填充站点母版页上的站点菜单。出于某种原因,C#代码隐藏文件无法识别SqlDataSource,也没有识别我在mater页面的aspx代码上放置的其他隐藏字段。 这是我的代码:

ASP:
<form id="Form1" runat="server">
<asp:ContentPlaceHolder ID="MainContent" runat="server">
  <asp:SqlDataSource ID="getButtons" runat="server" ConnectionString="<%$ ConnectionStrings:RMSConnectionString %>" SelectCommand="sp_getSiteMasterButtons" SelectCommandType="StoredProcedure">
    <SelectParameters>
      <asp:ControlParameter ControlID="idsid" Name="idsid" PropertyName="Value" Type="String" />
    </SelectParameters>
  </asp:SqlDataSource>

  <asp:HiddenField ID="idsid" runat="server" />

</asp:ContentPlaceHolder>
</form>

C#代码背后:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Windows.Forms;
using System.Data.SqlClient;

public partial class SiteMaster : System.Web.UI.MasterPage
{
    protected void Page_Load(object sender, EventArgs e)
    {

        idsid.Value = Environment.UserName;
        getButtons.DataBind();

    }
}

Error   1449    The name 'idsid' does not exist in the current context
Error   1450    The name 'getButtons' does not exist in the current context 

全部谢谢

3 个答案:

答案 0 :(得分:1)

SqlDataSource1.DataBind();

应该是

getButtons.DataBind();

答案 1 :(得分:0)

确保您拥有:

 <%@ Master Language="C#" AutoEventWireup="true" 
         Inherits="SiteMaster" CodeFile="Site.Master.cs" %>

中的

       Site.Master

答案 2 :(得分:0)

我认为你需要定义MasterType,以便子页面知道Master Page是什么类。这将使主页强列型。

请参阅MSDN documentation

<%@ MasterType virtualpath="~/Masters/Master1.master" %>

另外,我不确定ASPX页面上声明的控件是否默认为public。因此,您可能需要将它们添加为母版页上的属性,以便可以从其他类公开访问它们。

public SqlDataSource MasterDataSource {get {return this.getButtons;}}