如何显示html元素,在angularjs中选择特定的选项

How to show html element, on selecting specific option in angularjs?

本文关键字:选择 angularjs 选项 何显示 显示 元素 html      更新时间:2023-09-26

如何在angularjs中选择特定选项时显示其他html。当我们选择Other选项时,我想只显示From Date to Date文本字段,但是当我们选择其他选项时隐藏这些。我试了 ng-show="date_option=='Other',没有任何反应。

http://plnkr.co/edit/Xy49iha3bsCQui6uOaTV?p=preview

  <div ng-controller="ceilometerCtrl">
    <div id="ceilometer-stats">
         <form>
            <div class="form-group">
              <label>Period:</label>
              <div class="col-sm-2">
                <select ng-model="date_option" ng-options="value.label for value in date_options">
                </select>
              </div>
            </div>
            <div >
                  <label >From:</label>
                  <div class="col-sm-10">
                    <input type="text" id="date_from" name="date_from" />
                  </div>
                </div>
                <div>
                  <label>To:</label>
                  <div class="col-sm-10">
                    <input type="text" id="date_to" name="date_to"/>
                  </div>
               </div>
        </form>
    </div>
  </div>

"

var app=angular.module('hz',[]);
 app.controller('ceilometerCtrl', function($scope, $http){

   $scope.date_options=[
      {
           "value" : 1,
           "label" : "Last day"
      },
      {
           "value" : 7,
           "label" : "Last week"
      },
      {
           "value" : 23,
           "label" : "Month to date"
      },
      {
           "value" : 30,
           "label" : "Last 30 days"
      },
      {
           "value" : 356,
           "label" : "Last year"
      },
      {
           "value" : "Other",
           "label" : "Other"
      }
   ];
   $scope.date_option = $scope.date_options[1];
 });

根据你的js文件,看起来你需要使用ng-show="date_option.value=='Other'"

恰好

将ng-option更改为

ng-options="value.label as value.label for value in date_options" 

$scope.date_option = $scope.date_options[1].label;

或在ng-show中使用

ng-show="date_option.value=='Other'"