使用angularjs选择选项时,更新输入文本的值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用angularjs选择选项时,更新输入文本的值相关的知识,希望对你有一定的参考价值。

我的控制器在angularjs中有一个数组

app.controller('player', function($scope) {
    $scope.players = [
        {
            "id":3,
            "name":"Nadal",
        },
        {
            "id":4,
            "name":"Federer"
        }
    ]
});

在我的html中,我有一个带有dropdowntextbox的HTML。

 <html ng-app="pdl">  
    <body ng-controller="player">  
        <input type="text" id="name" value=""/>
        <select name="id">  
            <option ng-repeat="player in players" value="{{player.id}}">{{player.id}}</option>  
        </select>  
    </body>  
 </html>  

当我从下拉列表中选择一个选项时,我想用'名称'更新输入

答案

绑定选择和输入相同的ngModel

angular.module('pdl', []).controller('player', function($scope) {
  $scope.players = [{
    "id": 3,
    "name": "Nadal",
  }, {
    "id": 4,
    "name": "Federer"
  }]
});
<script src="https://code.angularjs.org/1.5.5/angular.min.js"></script>

<div ng-app="pdl" ng-controller="player">
  <input type="text" ng-model="player.name" />
  <select ng-model="player" ng-options="player as player.name for player in players">
  </select>
</div>
另一答案

上面的解决方案有效,但如果要在写入后修改输入值,则会中断。在上面的示例中,更改单词Nadal,并且选择也会更改,因为它们绑定到相同的值。

如果想要修改输入的值并且您不想绑定到同一个ngModel,则可以在select上使用ng-change,并将要在输入中显示的值传递给它。

在这个例子中,我在选择中插入“ng-change”语句...

ng-change="change(model.action)"

并在控制器中我更新输入的范围

    $scope.change = function (str) {
        $scope.model.action = str;
    };

每次更新选择时,输入也会更新,但您可以修改输入值而不触及选择,因为它们的绑定方式不同。

以上是关于使用angularjs选择选项时,更新输入文本的值的主要内容,如果未能解决你的问题,请参考以下文章

更改由AngularJs从Chrome内容脚本动态创建的包装选择的值

在AngularJS中选择一个输入字段时如何禁用一个输入字段? (都使用相同的 ng 模型)

使用 Web API 和 AngularJS 保存表单数据(选择列表)

angularjs的ng-change事件演示

Vuejs Bootstrap选择文本不更新

Angularjs使用选项从模板添加值创建文本区域