c# - 使用 Telerik RadGrid 如何从客户端隐藏 GridHyperLinkColumn?

标签 c# javascript asp.net telerik telerik-grid

我正在使用 Telerik RadGrid 并且正在执行客户端数据绑定(bind)。这是我的网格:

<telerik:RadGrid ID="radGrid_Assignments" runat="server" AllowPaging="True" AutoGenerateColumns="false" 
                     AllowSorting="true" AllowFilteringByColumn="true" >
        <PagerStyle Mode="NextPrevAndNumeric" />
        <MasterTableView NoMasterRecordsText="No assigments found for the search criteria.">
            <Columns>
                <telerik:GridHyperLinkColumn HeaderText="Customer Name" DataTextField="CustomerName" Target="_customer"
                                             DataNavigateUrlFormatString="~/Modules/DataEntry/ProviderContact/Edit.aspx?id={0}"
                                             DataNavigateUrlFields="CustomerID" SortExpression="cust.Name" UniqueName="cust.Name"
                                             HeaderStyle-Width="200px" />
                <telerik:GridBoundColumn DataField="JobTitle" HeaderText="Title" HeaderStyle-Width="250px" />
                <telerik:GridBoundColumn DataField="ProviderName" HeaderText="Provider" HeaderStyle-Width="250px" />
                <telerik:GridHyperLinkColumn DataNavigateUrlFields="SurveyType,EvaluationID,SurveyID" DataNavigateUrlFormatString="~/Modules/AssignmentPortal/Evaluation/Enter{0}.aspx?EvalID={1}&sid={2}&menu=false" DataTextField="SurveyName" HeaderStyle-Width="200px" HeaderText="Survey Name" SortExpression="s.Description" Target="_survey" UniqueName="s.Description" />
                <telerik:GridBoundColumn DataField="ProductName" HeaderText="Product" HeaderStyle-Width="150px" />
                <telerik:GridBoundColumn DataField="WorkPhone" UniqueName="cust.WorkPhone" SortExpression="cust.WorkPhone" HeaderText="Work Phone"
                                         HeaderStyle-Width="150px" />
                <telerik:GridHyperLinkColumn HeaderText="Email" DataTextField="Email" UniqueName="cust.Email"
                                             DataNavigateUrlFormatString="mailto:{0}" DataNavigateUrlFields="Email" SortExpression="cust.Email"
                                             HeaderStyle-Width="300px" />
                <telerik:GridBoundColumn DataField="NoteDateTime" HeaderText="Last Note Date" DataFormatString="{0:MM/dd/yyyy hh:mm tt}"
                                         HeaderStyle-Width="150px" />
                <telerik:GridBoundColumn DataField="NoteText" HeaderText="Last Note" UniqueName="cln.NoteText"
                                         HeaderStyle-Width="400px" />
            </Columns>
        </MasterTableView>
        <ClientSettings>
            <DataBinding Location="/AjaxServices/SearchService" SelectMethod="GetAssignmentsSearchResults" />
            <ClientEvents OnCommand="showLoadingPanel" OnDataBound="OnClientDataBound" OnDataBinding="OnClientDataBinding" />
        </ClientSettings>
    </telerik:RadGrid>

当 SpatialCoordinatesKLASID 的 DataNavigateUrlFields 为 NULL 时,我希望能够使用 HeaderText="KLAS Maps"隐藏 GridHyperLinkColumn。我只想要一个空列。

我无法使用服务器端 OnItemDataBound 事件的传统方式。因为这是在客户端加载。

我该怎么做?预先感谢您的帮助。

最佳答案

请尝试以下代码/演示。

 function DataBound(sender, args) {

            var grid = $find("<%= RadGrid1.ClientID %>");
            if (grid) {

                var IsColumnHaveData = false;
                var MasterTable = grid.get_masterTableView();
                var Rows = MasterTable.get_dataItems();
                for (var i = 0; i < Rows.length; i++) {
                    var row = Rows[i];


                    if (row.get_dataItem().EmployeeName != null) {
                        IsColumnHaveData = true;
                    }

                }


                var Columns = MasterTable.get_columns();
                for (var i = 0; i < Columns.length; i++) {
                    var column = Columns[i];
                    if (column.get_uniqueName() == "EmployeeName") {
                        column.set_visible(IsColumnHaveData);
                    }
                }

            }


        }



<ClientSettings>
            <DataBinding Location="http://localhost/WcfService1/Service1.svc" SelectMethod="GetData"
                SortParameterType="Linq" FilterParameterType="Linq">
            </DataBinding>
            <ClientEvents OnDataBound="DataBound" />
        </ClientSettings>

请在下面的链接代码/演示中应用以上代码。

RadGrid with WCF Rest Service

隐藏特定链接。

函数数据绑定(bind)(发送者,参数){

            var grid = $find("<%= RadGrid1.ClientID %>");
            if (grid) {

                var IsColumnHaveData = false;
                var MasterTable = grid.get_masterTableView();
                var Rows = MasterTable.get_dataItems();
                for (var i = 0; i < Rows.length; i++) {
                    var row = Rows[i];
                    row.get_cell("EmployeeName").getElementsByTagName("a")[0].style.display = 'none';
                }
            }
        }

关于c# - 使用 Telerik RadGrid 如何从客户端隐藏 GridHyperLinkColumn?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12755209/

相关文章:

c# - 调用 ToList() 时是否会影响性能?

当表单关闭事件被触发时关闭我的小游戏的 C# 问题

javascript - 如何遍历 Typescript : for. ..in 中的 map ?为了……的?为每个?

asp.net - 在Telerik RadGrid中访问行数据(服务器端)

jquery - 如何将 ASPX 页面加载到 JQuery 对话框中

c# - 使用参数从 DbCommand 获取 SQL 查询字符串

c# - Task.ContinueWith 在非异步方法中的性能与使用 async/await 的对比

javascript - 创建一个 DIV onclick

javascript - 将 JSON 转换为 topoJSON 时出现意外的线/多边形

javascript - Visual Studio Bundle for SPA html 索引页