2016-03-21 11 views
0

単純なng-selectの値をコントローラに渡し、if文を使用して、選択した値がI次のように、必要に:シンプルでコントローラでng-selectとif else文を使用する

HTML

<form role="form"> 
    <div class="form-group"> 
    <label for="selectAnswerPhaseOneQuestionOne">Select answer:</label> 
    <select class="form-control" id="selectAnswerPhaseOneQuestionOne" 
    data-ng-model="questionOneAnswer" data-ng-dropdown required 
    name="type"> 
     <option></option> 
     <option value="True">True</option> 
     <option value="False">False</option> 
    </select> 
    </div> 
</form> 

<button data-ng-click="submitPhaseOneAnswers()" 
class="btn btn-primary" type="submit"> 

JS

$scope.questionOneAnswer = ''; 

$scope.submitPhaseOneAnswers = function() { 
    var score = 0; 
    if($scope.questionOneAnswer == 'True') { 
    score = score + 10; 
    alert('Your score is now ' + score); 
    } 
} 

ボタンをクリックするだけでif文がバイパスされます。最後に、私が概説した上記のコードは、私が実際にHTMLで選択したグループの4倍を含んでいます。ボタンを押すと、TrueかFalseかを評価する必要があります。

+0

は、デバッガで$ scope.questionOneAnswerの値を調べることはできますか?コントローラの依存関係に$ scopeを追加しましたか? – TSungur

+1

コードが実行しようとするとうまくいくが、それはまったくではない。アラートポップアップが表示されず、コンソールログも追加されましたか?申し訳ありませんが、私はもちろん私のコントローラーで$ scopeを宣言しました。 –

+0

あなたの質問は今答えられていますか? –

答えて

0

使用ng-options

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

 
app.controller("myCtrl", function ($scope) { 
 
    $scope.options = ['True', 'False']; 
 

 
    $scope.submitPhaseOneAnswers = function() { 
 
    var score = 0; 
 
    
 
    if($scope.questionOneAnswer == 'True') { 
 
     score += 10; 
 
    } 
 
    
 
    alert('Your score is now ' + score); 
 
    } 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.8/angular.min.js"></script> 
 

 
<form role="form" ng-app="myApp"> 
 
    <div class="form-group" ng-controller="myCtrl"> 
 
    <label for="selectAnswerPhaseOneQuestionOne">Select answer:</label> 
 
    <select class="form-control" id="selectAnswerPhaseOneQuestionOne" 
 
    ng-model="questionOneAnswer" name="type" ng-options="option as option for option in options"></select> 
 
    <button ng-click="submitPhaseOneAnswers()" class="btn btn-primary">Submit</button> 
 
    </div> 
 
</form>

+0

こんにちはアレキサンダー、提案のおかげで。私はまだ同じ問題を抱えています。とにかく実行されるときに必要ではないことを前にアドバイスされているので、私はHTMLに「ng-controller」ステートメントを入れていないことに注意してください。また、ボタンがフォームの外にあるので、これが問題の原因になっているかどうかはわかりません。 –

0

コードをステップごとに確認できます。

  1. (同じ名前を持つ)HTMLファイルとJSファイルに

  2. をコントローラ名を確認プットにconsole.log()関数$ scope.submitPhaseOneAnswersで()時にクリックボタン、それが実行されているかどうかを確認します。

  3. 機能がうまくいくと、おそらく$ scope.questionOneAnswer = ''が原因でエラーが発生します。

+0

これをコンソールログに入れて試してみましたが、コンソールに次のようなメッセージが表示されました。 'Error:too recursion ....' –