javascript - AngularJS 使用 selectize 和 ng-repeat 设置多选下拉列表的值

标签 javascript html angularjs selectize.js multiple-select

通过这个例子(JS Bin of pure html select tag)我可以实现纯html的多选。

但是我正在使用selectize插件
https://selectize.github.io/selectize.js/
对于下拉多选,我很困惑如何填充已选择的值。?

这是我尝试过的我的HTML:

<div ng-repeat="item in items">

<select  
multiple 
class="selectSkill"
ng-model="item.storedArray"
ng-options="opt.skillId as opt.skillName for opt in skills"
></select>

</div>

我的客户:

$scope.$selectSkill= $('.selectSkill').selectize({
    valueField: 'skillId',
    labelField: 'skillName',
    searchField: 'skillName',
    maxItems: 5,
    placeholder:"Select Skill",
    options: $scope.skills,
    create: false,
    sortField: {
        field: 'skillName',
        direction: 'asc'
    }
});
$scope.selectizeControlSkills = $scope.$selectSkill[0].selectize; 

我正在使用基于类的(selectSkill)加载selectize。

没有填充,正常负载就可以工作,但我正在尝试使用动态选择来设置值。

感谢您的帮助。

我的演示数据:

**$scope.skills**

enter image description here

**item.storedArray**

enter image description here

最佳答案

发布我创建的示例作为答案,因为它似乎对OP有帮助。

这里的建议是不要将 Selectize 与 ng-model 混合使用。和ng-options因为如果应用于相同的select,它们在功能上会相互冲突。元素。

如果您想使用 Selectize,最好创建一个包装器(即指令,如我的示例中所示),它提供 select 上的初始化。需要它的元素。

另外,不要忘记,由于 Selectize 会导致 AngularJS 上下文之外的数据更改,因此您需要手动触发摘要(即 scope.$apply() )以确保 AngularJS 内的代码看到最新数据。

angular
  .module('app', [])
  .controller('ctrl', function ($scope) {
    $scope.items = [
      { storedArray: ['078...'] },
      { storedArray: [] },
      { storedArray: ['0cc...'] },
    ];
    $scope.skills = [
      { skillId: '078...', skillName: 'Java' },
      { skillId: '0cc...', skillName: 'Cisco UCS' },
    ];
    $scope.itemSelectizeOptions = $scope.items.map(function (item) {
      return {
        valueField: 'skillId',
        labelField: 'skillName',
        options: $scope.skills,
        items: item.storedArray,
        onChange: function (newItems) {
          item.storedArray = newItems;
          // `$apply()` needed because change occurs outside of AngularJS's knowledge
          $scope.$apply();
        }
      };
    })
  })
  .directive('selectize', function () {
    return {
      scope: {
        selectize: '<',
      },
      link: function (scope, el) {
        var selectize = $(el).selectize(scope.selectize);
      },
    };
  });
<link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/selectize.js/0.12.6/css/selectize.min.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.7.2/angular.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/selectize.js/0.12.6/js/standalone/selectize.min.js"></script>
<div ng-app="app" ng-controller="ctrl">
  <div ng-repeat="options in itemSelectizeOptions">
    <select
      multiple
      selectize="options"></select>
  </div>
  <pre>{{ items | json }}</pre>
</div>

关于javascript - AngularJS 使用 selectize 和 ng-repeat 设置多选下拉列表的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52193740/

相关文章:

javascript - 在动态生成列表项时卡在 jquery 中

javascript - 为什么 JavaScrips 仅在加载页面后才起作用?

javascript - 如何在 AngularJS 中创建动态过滤器?

javascript - 等待编程滚动 Selenium /Protractor

javascript - $scope.currentPage 不更新 - Angular Ui 分页

javascript - JQuery 无法从单选按钮读取值

javascript - ionic 3 条件下的颜色变化

javascript - 如果弹出窗口被打开,则禁止刷新

javascript - 检查必填项而不对隐藏字段进行求和

html - 当父 div 高度为 100% 时子 div 的高度