0

与えられたように、ツリー ビュー内にプログレス バーをバインドしました。

<script id="progressField" type="text/x-kendo-template">
  #if(CurrentStatus == "Progress")
  {#
     <div class='progressDetails'></div>
  #}
  else if(CurrentStatus == "Error")
  {#
      // Other task
  #}
</script>

与えられたツリーリストビューに同じものを追加しました

columns: [ 
    { field: "CurrentStatus", title: "Status", template: $("#progressField").html(), width: "170px" }
],

そしてDataBoundで同じことを更新しました

    function dataBound(e) {

     var tree = this;
     $(".progressDetails").each(function () {
     var row = $(this).closest("tr");
     var model = tree.dataItem(row);

     $(this).kendoProgressBar({

      change: function (e) {
       if (model.CurrentStatus == "Progress") {
           colorCode = "#235400";
       } 

       this.progressWrapper.css({
            "background-color": colorCode,
            "border-color": colorCode
       });

     }
  });

  $(this).data("kendoProgressBar").value(model.Percentage);
  });
};

ロード、ソート、およびツリー リストのフィルタリング時に、進行状況バーが表示されます。ただし、展開矢印をクリックすると、進行状況バーが表示されません。

4

1 に答える 1

0

最後に解決策を見つけました。問題はCollapseで、expandメソッドがすぐにトリガーされました。

タイムアウトを追加し、動作を開始しました..

expand: function(e){
 var scope = e
 setTimeout(function(){
   $scope.expandOrCollapse(scope);
 }, 0)
}        

これが作業道後です。

http://dojo.telerik.com/OLiFE/18

于 2016-12-13T05:38:21.490 に答える