首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用ng-重复时动态设置ng-模型名称(或如何使用ng-重复项值作为ng-模型名称)

使用ng-重复时动态设置ng-模型名称(或如何使用ng-重复项值作为ng-模型名称)
EN

Stack Overflow用户
提问于 2018-04-10 06:11:47
回答 1查看 53关注 0票数 0

我有一些字段是基于ng-重复动态生成的。但是,我需要动态地为这些字段设置ng模型名称,这应该是基于来自ng-重复的$index,或者应该将ng-重复项值作为ng-模型的名称。

下面是我的代码

代码语言:javascript
复制
 <div class="panel-body"
                        data-ng-controller="XModelController as xmdlCtrl">

 ................

 ................

 <th data-ng-repeat="item in ['xmdlCtrl.rsptYrs.year1Date', 'xmdlCtrl.rsptYrs.year2Date', 'xmdlCtrl.rsptYrs.year3Date', 'xmdlCtrl.rsptYrs.year4Date', 'xmdlCtrl.rsptYrs.year5Date', 'xmdlCtrl.rsptYrs.year6Date'] | limitTo: xmdlCtrl.colCount"><section col col-11>Year{{$index+1}}</section>

 <section col col-11>
   <label class="input"> <input id="year{{$index+1}}" 
          placeholder="MMM-YYYY" required="required" data-ng-model="'xmdlCtrl.rsptYrs.year{{$index+1}}Date" /</label></section></th>

 ........................

上面的代码在执行时会创建一个令牌错误,因为它不允许'{{}}'

我的实际要求是,我希望ng模型具有以下名称

ng-model="xmdlCtrl.rsptYrs.year1Date" ng-model="xmdlCtrl.rsptYrs.year2Date"

以此类推,基于ng重复的$index值(这实际上等于xmdlCtrl.rsptYrs.year($index+1)Date )。

我曾经历过类似的帖子,但似乎没有一篇文章对此有一个准确的解决方案。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-10 06:34:33

代码语言:javascript
复制
angular.module('app', []).controller('ctrl', function($scope){
  $scope.items = [{test1: 1}, {test2: 1}]
})
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>

<div ng-app='app' ng-controller='ctrl'>
  <input ng-repeat-start='item in items' ng-model="item['test' + ($index + 1)]" type='number'/>  
  <br ng-repeat-end>
  {{items | json}}
</div>

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49746520

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档