angularjs在ng-model中添加空格

问题描述 投票:0回答:2

我在ng-model上有这个<input name="Name" type="text" id="Name" class="step-input" placeholder="NAME*" readonly="readonly" ng-model="(ContactPerson)+(ContactPersonSurname)" />,它连接两个字段并且工作正常,但我想使用angular在(ContactPerson)和(ContactPersonSurname)之间添加空格。我怎样才能做到这一点?

angularjs-directive angularjs-ng-model
2个回答
0
投票

如果你在ng-model指令中提供表达式,你会得到一个[ngModel:nonassign]错误,在Angularjs documentation中他们清楚地说明了

当ngModel指令绑定到的表达式是不可赋值的表达式时,会发生此错误。 始终确保可以将通过ngModel指令绑定的表达式分配给。

解: 创建一个新的$ scope变量 然后$scope.fullName = (ContactPerson)+ ' ' +(ContactPersonSurname);在你的html中使用它,如下所示。

angular.module('mainApp', [])
    .controller('mainCtrl', function ($scope) {
       $scope.name = "john";
      $scope.surName = "Doe";
      $scope.fullName = $scope.name + " " + $scope.surName;
    });
<html ng-app="mainApp">
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width">
  <title>JS Bin</title>
</head>
<body ng-controller="mainCtrl">
  <input type="text" ng-model="fullName" />
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.min.js"></script>
</body>
</html>

0
投票

您的输入字段是只读的。所以你可以使用expressins而不是绑定模型。

var myApp = angular.module('myApp',[]);

function MyCtrl($scope) {
    $scope.ContactPerson = 'foo';
    $scope.ContactPersonSurname = 'bar';
}
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>

<div ng-app="myApp">

<div ng-controller="MyCtrl">
  <input name="Name" type="text" id="Name" class="step-input" readonly="readonly" value="{{ContactPerson}} {{ContactPersonSurname}}"  />
</div>
</div>

希望这能解决你的问题。

© www.soinside.com 2019 - 2024. All rights reserved.