【问题标题】:Assign Tooltip to cell of selected row in Infragistics WebDataGrid将工具提示分配给 Infragistics WebDataGrid 中选定行的单元格
【发布时间】:2015-08-18 15:21:46
【问题描述】:

我有一个包含组名的 Infragistics WebDataGrid。我想在用户选择它时向组单元格添加一个工具提示,其中列出与该组关联的医生。 我创建了一个行选择事件,该事件在选择组行时获取医生的姓名。该方法如下,并在选择行时返回名称。当我将字符串分配给工具提示时,当您将鼠标悬停在单元格上时,工具提示不会显示。

protected void wdgMedGrp_RowSelected(object sender, Infragistics.Web.UI.GridControls.SelectedRowEventArgs e)
        {
            Infragistics.Web.UI.GridControls.SelectedRowCollection selectedRows = e.CurrentSelectedRows;
            int iMedicalGroupID = Convert.ToInt32(selectedRows[0].Items.FindItemByKey("ID").Value.ToString());

            //Get Doctor names for this group
            DataTable dtDoctors = new DataTable("Doctors");

            SqlConnection SqlConn = null;
            string strSqlConnection = ConfigurationManager.ConnectionStrings["CAP06"].ConnectionString;
            using (SqlConn = new SqlConnection(strSqlConnection))
            {
                using (SqlCommand SqlCmd = new SqlCommand("phyadmGetPhysicianNames", SqlConn))
                {
                    SqlCmd.CommandType = CommandType.StoredProcedure;
                    SqlCmd.Parameters.Add("@MedicalGroupID", SqlDbType.Int).Value = iMedicalGroupID;
                    SqlConn.Open();
                    using (SqlDataAdapter dataReturned = new SqlDataAdapter(SqlCmd))
                    {
                        dataReturned.Fill(dtDoctors);
                    }
                }
            }

            string strPhysicianNames = string.Empty;
            foreach(DataRow row in dtDoctors.Rows)
            {
               strPhysicianNames += row["PhysicianFullName"].ToString() + "\r\n";
            }

            selectedRows[0].Items.FindItemByKey("Name").Tooltip = strPhysicianNames;
        }

这是我的标记:

<ig:WebHierarchicalDataGrid runat="server" height="600px" width="875px" 
AutoGenerateBands="False" AutoGenerateColumns="False" DataKeyFields="ID"
DataMember="SqlDataSource3_DefaultView" StyleSetName="Windows7" ID="wdgMedGrp"
DataSourceID="WebHierarchicalDataSource2" Key="SqlDataSource3_DefaultView" 
OnRowAdded="wdgMedGrp_RowAdded" OnRowSelectionChanged="wdgMedGrp_RowSelected">
<Columns>
    <ig:BoundDataField DataFieldName="ID" Key="ID" Hidden="true">
        <Header Text="ID" />
        <header text="ID" />
    </ig:BoundDataField>
    <ig:BoundDataField DataFieldName="Name" Key="Name" Width="68%">
        <Header Text="Name" />
        <header text="Name" />
    </ig:BoundDataField>
    <ig:BoundDataField DataFieldName="IsVisible" Key="IsVisible" Width="22%">
        <Header Text="Is Visible?" />
        <header text="Is Visible?" />
    </ig:BoundDataField>
</Columns>
 <Behaviors>
    <ig:Filtering>
    </ig:Filtering>
    <ig:RowSelectors EnableInheritance="True" RowSelectorCssClass="groupRowSelectorWidth">
    </ig:RowSelectors>   
    <ig:Selection RowSelectType="Single" Enabled="true" CellClickAction="Row">
        <AutoPostBackFlags RowSelectionChanged="true" />
    </ig:Selection>     
 </Behaviors>   

为什么工具提示不显示?

谢谢。

【问题讨论】:

    标签: c# tooltip infragistics webdatagrid


    【解决方案1】:

    我也有类似的需求。我通过为每一行创建另一个包含我想要的工具提示的隐藏列来解决它,然后在 InitializeRow 事件中设置工具提示,如下所示:

    Protected void wdgMedGrp_InitializeRow(object sender, RowEventArgs e)
    {
        try
        {
           e.Row.Items[1].Tooltip = e.Row.Items[2].Value.ToString();
        }
        catch (Exception){} // ignore any exceptions
    }
    

    效果很好。不利的一面是我必须为每条记录执行一次,这意味着我无法使用 SQL 调用中的 .Fill() 方法。

    【讨论】:

    • 感谢您的回复。我决定换个方向,将这些信息放在不需要工具提示的不同页面上。以防万一,这可能会奏效。我必须创建一个值字符串的数据库调用。在此方法中分配工具提示确实会显示信息。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-07-14
    • 2018-06-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-04-21
    相关资源
    最近更新 更多