1

Telerik RadGridを使用しており、クライアント側のデータバインドを行っています。これが私のグリッドです:

<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 ="KLASMaps"を使用してGridHyperLinkColumnを非表示にできるようにしたいと思います。空の列が欲しいだけです。

サーバー側のOnItemDataBoundイベントを使用する従来の方法を使用することはできません。これはクライアント側で読み込まれているためです。

これどうやってするの?よろしくお願いします。

4

2 に答える 2

3

以下のコード/デモでお試しください。

 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>

以下のリンクコード/デモで上記のコードを適用してください。

WCFRestServiceを使用したRadGrid

特定のリンクを非表示にします。

関数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];
                    row.get_cell("EmployeeName").getElementsByTagName("a")[0].style.display = 'none';
                }
            }
        }
于 2012-10-06T04:53:54.133 に答える
0

jQueryのonloadを介して控えめなJavaScriptを使用します。このjsfiddleをチェックしてください。

適切な機能を実現するには、生成されたHTMLを分析する必要があります。

于 2012-10-05T23:49:13.987 に答える