How to assign selected option's text to another model while using ng-options?

前端 未结 3 589
情深已故
情深已故 2021-01-22 21:31

I can create a select tag and place data inside it. I can assign that select\'s selected option to a model but can\'t assign its text to another model.

Here is example b

相关标签:
3条回答
  • 2021-01-22 21:55

    Solution: Please Check this.This will resolve your problem Once you select from DROPDOWN the selected Object will be stored in customer. Then this customer object contains id as well as name

    MISTAKE you have made is

         ng-model="customerId"  ng-options="item.id as item.name for item in content"
    

    Here ONLY item.id will be collected to customerId

    If you want whole object then DO LIKE BELOW

        <div ng-app>
         <div ng-controller="DemoCtrl">
            <select ng-model="customer" ng-options="item.name for item in content" ng-change="customerName = item.name">
           </select>
           <br/>
           <input disabled="disabled" type="text" ng-model="customer.id"/>
           <input disabled="disabled" type="text" ng-model="customer.name"/>
         </div>
         </div>
    
    0 讨论(0)
  • 2021-01-22 21:59

    Please see demo below In select change your model to cutomer and in inputs use customer.id customer.name

    function DemoCtrl($scope) {
      $scope.content = [{
        name: "Bireysel",
        id: 1
      }, {
        name: "Kurumsal",
        id: 2
      }, {
        name: "Bireysel & Kurumsal",
        id: 3
      }];
    
    }
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
    <div ng-app>
      <div ng-controller="DemoCtrl">
        <select ng-model="customer" ng-options="item as item.name for item in content" ng-change="customerName = item.name">
        </select>
    
        <br/>
        <input disabled="disabled" type="text" ng-model="customer.id" />
        <input disabled="disabled" type="text" ng-model="customer.name" />
      </div>
    </div>

    0 讨论(0)
  • 2021-01-22 22:02

    Try this:

    <select ng-model="customer" ng-options="item.name for item in content">
    

    and

    <input disabled="disabled" type="text" ng-model="customer.id"/>
    <input disabled="disabled" type="text" ng-model="customer.name"/>
    

    jsfiddle

    0 讨论(0)
提交回复
热议问题