Kendo UI MVVM具有不同的模板引擎

时间:2013-11-15 21:06:25

标签: angularjs kendo-ui

我已经在多个地方读过,可以将Kendo UI的MVVM系统与不同的模板引擎一起使用。

我喜欢Kendo,我喜欢小部件,我喜欢简单的View Models - 但我讨厌他们的模板。它们非常严格。

但我遇到麻烦的是找到任何方法来做到这一点;我很想将AngularJS用于模板......但我不希望它超出任何范围。我对声明从Angular调用我的所有小部件不感兴趣,我只需要能够将小部件数据绑定到kendo视图模型,并使用Angular来呈现转发器部分等。

这可能吗?我见过AngularJS-Kendo项目,似乎没有做我想做的事情。它只适用于声明性小部件绑定。

1 个答案:

答案 0 :(得分:1)

我不完全确定你的想法,但这是我对此的看法。 我认为没有办法将Angular模板的使用与使用控制器和模型的概念分开。

因此,您可能必须找到一种方法将视图模型与这些模型集成。我不知道这是否对你有所帮助,但我把一个简单的(可能是笨拙的)组合一个Kendo视图模型和Angular模板以及使用相同的视图模型和一个Kendo下拉列表的例子: / p>

<强> HTML

  <div ng-controller="MainCtrl">
      <clickable items="items"></clickable>
      <ul>
          <li ng-repeat="item in items.slice(0,items.length)">
              {{ item.text }} ({{ item.value }})
          </li>
      </ul>
  </div>

<强>的JavaScript

app = angular.module('app', []);

var items = [
             { text: "test 0", value: 0},
             { text: "test 1", value: 1}
            ];

var viewModel = kendo.observable({
    items: items
});

viewModel.bind("change", function(e) {
  console.log("change");
});

app.controller('MainCtrl', function($scope) {
  $scope.items = viewModel.get("items");
});

app.directive('clickable', function() {  
  return {
      restrict: "E",
      scope: {
          items: '='
      },
      template: "<button>Click to Add</button>",
      link: function(scope, element, attrs) {
          element.bind('click', function() {
              var index = scope.items.length;
              var text =  "test " + index;
              scope.items.push({ text: text, value: index});

              scope.$apply();
          });
      }
  };
});

$("#tree").kendoDropDownList({
    dataTextField: "text",
    dataValueField: "value",
    dataSource: viewModel.get("items"),
    change: function (e) {
        console.log("dropdown value change: " + this.value());
    }
});

对应的JSBin:http://jsbin.com/UBuPUwOq/5/edit

Angular-Kendo基本上简化了一些事情,因此您不必强制创建小部件。相反,您可以以与Angular控制器和模型集成的方式创建它们:

<select kendo-drop-down-list
        k-option-label="'Select A Thing'"
        k-data-text-field="'name'"
        k-data-value-field="'id'"
        k-data-source="things"></select>