Ionic 和 Angularjs - 形式绑定似乎只是一种方式

Ionic and Angularjs - form binding appears to be only one way.?

本文关键字:方式 一种 Angularjs 绑定 Ionic      更新时间:2023-09-26

我有一个项目列表。它们是保存在 itemArray 中的对象。当你触摸一个时,它会触发ng-click="openEditor(item)"。喜欢这个:

<ion-list>
  <ion-item ng-repeat="item in ItemArray" class="item item-avatar" ng-click="openEditor(item)">
    <img ng-src="{{iconMap[item.type]}}">
    <h2>{{item.dateString}}</h2><span>{{item.startTimeString}}</span>
    <p>ASA {{item.priority}}: {{item.itemType}}</p>
  </ion-item>
</ion-list>

然后就会发生这种情况:

$scope.openEditor =function(item){ 
   $scope.currentItem = item;
   $scope.modal.show();
}

在我有的模态中

<select ng-model="currentItem.priority">
          <option value="1">1</option>
          <option value="2">2</option>
          <option value="3">3</option>
          <option value="4">4</option>
          <option value="5">5</option>
        </select>

它在下拉列表中显示了正确的优先级(我已经用很多项目对其进行了测试)。

问题是 - 我无法改变它!如果我尝试,我无法更改下拉列表中的选项。

我收到此错误:

TypeError: Cannot assign to read only property 'priority' of #<Object>

为什么会这样?我想更改优先级,然后将其保存回itemArray和SQL DB。

听起来您尝试更改的对象是只读的。您需要调查为什么会这样,但您可以使用

$scope.openEditor =function(item){ 
   $scope.currentItem = angular.copy(item);
   $scope.modal.show();
}