2017-05-30 13 views
0

私は、MongoDBから取得した都市名を持つ選択ボックスを持つMEANスタック上にWebサイトを構築しました。今度はHTMLでこれらの名前を表示するためにAngularを使用しますが、ページがロードされたときにデフォルトの名前を表示して、少なくともいくつかの情報が表示されるようにします。私はすでに何を使うことができるのか調べてきましたが、ng-initが提案されましたが、これは私にとってはうまくいかなかったのです。他のオプションはありますか?ページ更新時にデフォルトで選択された項目を取得する

これは私のHTMLです:

<div ng-controller="cityCtrl"> 
    <div class="container plumbers"> 
    <div class="searchbox"> 
     <div class="plumber-by-city col-sm-12" style="margin-bottom: 20px;"> 
     <div class="title-1">Zoek op plaatsnaam</div> 
      <select ng-model="selectedItem" ng-options="item as item.city for item in items"></select><span class="fa fa-caret-down"></span> 
     </div> 
    </div> 
    </div> 
</div> 

これは、DBからデータを取得し、私の角度です:

app.controller('cityCtrl', function($scope,$http){ 
    $scope.items = []; 

    $http.get('/getdata').then(function(d){ 
    console.log(d); 
    $scope.items = d.data; 
    },function(err){ 
    console.log(err); 
    }); 
}); 
+1

あなたは 'selectedItem'を初期化する必要があります。 $ scope.selectedItem = $ scope.items [0] ' –

+0

ハディの答えに代えて、' $ scope.items = [{city:amsterdam}] 'を初期化するか、あなたの応答は –

+0

と表示されます。デフォルトの 'selectedItem'として? –

答えて

0

あなたはこのようなselectedItemの値が、その後がある場合はそのng-selected||演算子を使用することができますそれが選択されるか、または配列の最初のオブジェクトがデフォルトで選択されます。

var app = angular.module("MyApp", []).controller("cityCtrl", function($scope) { 
 
$scope.items = [{city: 'abc'}, {city: 'cde'}, {city: 'fgh'}]; 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> 
 
<div ng-app="MyApp" ng-controller="cityCtrl"> 
 
    <div class="container plumbers"> 
 
    <div class="searchbox"> 
 
     <div class="plumber-by-city col-sm-12" style="margin-bottom: 20px;"> 
 
     <div class="title-1">Zoek op plaatsnaam</div> 
 
      <select ng-selected="selectedItem = selectedItem || items[0]" ng-model="selectedItem" ng-options="item as item.city for item in items"></select><span class="fa fa-caret-down"></span> 
 
     </div> 
 
     {{selectedItem}} 
 
    </div> 
 
    </div> 
 
</div>

関連する問題