在Datepicker

时间:2018-05-18 00:04:51

标签: javascript angularjs angularjs-scope angularjs-ng-change

我遇到过一个看似非常简单的问题,但我无法弄清楚如何修复它。我最初发布了this question,但问题似乎与范围有关。

基本上,这就是发生的事情:

  • 我在表单中有一个日期选择器。当用户选择日期时,ng-change将触发,并调用函数setDate(date)
  • 在调试模式下,我确认所选数据确实传递给了函数。
  • 在函数内部,$ scope.simStartDate变量被赋予此值,我可以看到它的值发生变化。
  • 但是,当我稍后提交表单时,$scope.simStartDate会返回原始初始值。
  • 我在初始化$scope.simStartDate = new Date()上放了一个断点,但它没有命中。意味着变量未再次初始化。
  • 我尝试在ng-model中使用$ scope变量,但问题仍然存在。

这让我觉得ng-change创建了一个本地范围并更新了一个我以后无法访问的局部变量。我的理解是否正确?如果没有,我该如何解决这个问题?

这是我的HTML:

<div class="row" ng-controller="DashboardParamsFormCtrl">
    <div class="col-sm-6">
        <div class="form-group">
            <label for="inputFirstName">Simulation start date</label>
            <p class="input-group">
                <input type="text" class="form-control"
                       uib-datepicker-popup="{{format}}"
                       datepicker-options="options"
                       ng-model="date"
                       ng-change="setDate(date)"
                       is-open="opened" ng-required="true"
                       close-text="Close"
                       alt-input-formats="altInputFormats"
                       show-button-bar="true" />
                <span class="input-group-btn">
                    <button type="button" class="btn btn-default"
                            ng-click="open()">
                        <i class="glyphicon glyphicon-calendar"></i>
                   </button>
               </span>
            </p>
        </div>
    </div>

这是JS:

    angular.module('BlurAdmin.pages.dashboard')
        .controller('DashboardParamsFormCtrl', DashboardParamsFormCtrl);

    /** @ngInject */
    function DashboardParamsFormCtrl(baConfig, layoutPaths, baUtil, $scope)
    {
       $scope.ParamsFormBtnClicked = function()
       {
           console.log("Date: " + $scope.simStartDate);
       }

        $scope.open = open;

        $scope.opened = false;
        $scope.formats = ['dd-MMMM-yyyy', 'yyyy/MM/dd', 'dd.MM.yyyy', 'shortDate'];
        $scope.format = $scope.formats[0];
        $scope.options = {
            showWeeks: false
        };
        function open() {

            $scope.opened = true;
        }

        $scope.simStartDate = new Date();
        $scope.date = new Date();

        $scope.setDate = function(startDate)
        {
            $scope.simStartDate = startDate;
        }

    }
})();

谢谢。

1 个答案:

答案 0 :(得分:1)

你传递的新日期();没有价值,它将获得当前日期。你应该在新的日期();

中传递ng-model值 像这样。

$scope.simStartDate = new Date(date);
$scope.date = new Date(date); 

希望此链接也能为您提供帮助plnkr