如何发送数据源参数来选择函数

时间:2012-12-24 09:45:29

标签: c# asp.net

修改

这是我的新尝试:

现在我正在ObjectDataSource 'MenuDataSource' could not find a non-generic method 'GetData' that has no parameters.

     <asp:ObjectDataSource 
     ID="GridDataSource"            
      SelectMethod="GetData"
      TypeName="Model.GridProvider"
      runat="server"  > 
     <SelectParameters>
        <asp:Parameter Name="MenuItemID" Type="Int32" DefaultValue="10"  />
      </SelectParameters>
      </asp:ObjectDataSource>


public int DbToAccess
    {
        get
        {
            return SiteMaster.Current_MenuItemID;
        }
    }


[DataObject(true)]
public static class MyMenuProvider
{
        [DataObjectMethod(DataObjectMethodType.Select)]
        public static HierarchicalCollection GetData(int inputMenuItemID)
        {
            return GetCollection(inputMenuItemID);
        }

}

我该怎么做?

2 个答案:

答案 0 :(得分:1)

您可以使用public参数,其get调用将转到DataSource并获取其set参数。或者甚至更好的是将它的值存储在会话变量中的公共参数,并且Select Function和DataSource都访问Parameter。 像这样:

    public string MyParam
    {
           get
           {
                 return Session["MyParamStr"].ToString();
           } 
           set 
           {
                Session["MyParamStr"] = value;
           }
    }

然后在你的标记中

    <asp:Parameter value='<%# MyParam %>' />

答案 1 :(得分:1)

答案是我很蠢 TypeName="Model.GridProvider" 我把select方法放在上面的类是 MyMenuProvider

更改为

public static class GridProvider
{
    [DataObjectMethod(DataObjectMethodType.Select)]
    public static DataTable GetData(int MenuItemId)
    {
        return GuiCreators.getDataTable("");

    }


    public static void GetCommand(int id)
    {

    }


}

并且我的麻烦在哪里解决了