Выбор даты угловой начальной загрузки

#angularjs #angular-ui-bootstrap

#angularjs #angular-ui-bootstrap

Вопрос:

Я использую angular-ui-bootstrap datepicker, и я хочу использовать следующий формат ввода ‘ddMMyyyy’ для моего ввода. На самом деле ng-change вызывается при вводе этого формата во входных данных, но я хочу, чтобы после ng-change входные данные менялись на формат ‘дд / ММ / гггг’, точно так же, как при выборе даты в календаре выбора даты. Как я могу это сделать? Вот пример кода plnkr

https://plnkr.co/edit/Njetw7fVfZATxruuUI3m?p=preview

  angular.module('ui.bootstrap.demo', ['ngAnimate', 'ngSanitize', 'ui.bootstrap']);
angular.module('ui.bootstrap.demo').controller('DatepickerPopupDemoCtrl', function ($scope) {
  $scope.today = function() {
    $scope.dt = new Date();
  };
  $scope.today();

  $scope.clear = function() {
    $scope.dt = null;
  };

  $scope.inlineOptions = {
    customClass: getDayClass,
    minDate: new Date(),
    showWeeks: true
  };

  $scope.dateOptions = {
    dateDisabled: disabled,
    formatYear: 'yy',
    maxDate: new Date(2020, 5, 22),
    minDate: new Date(),
    startingDay: 1
  };

  // Disable weekend selection
  function disabled(data) {
    var date = data.date,
      mode = data.mode;
    return mode === 'day' amp;amp; (date.getDay() === 0 || date.getDay() === 6);
  }

  $scope.toggleMin = function() {
    $scope.inlineOptions.minDate = $scope.inlineOptions.minDate ? null : new Date();
    $scope.dateOptions.minDate = $scope.inlineOptions.minDate;
  };

  $scope.toggleMin();

  $scope.open1 = function() {
    $scope.popup1.opened = true;
  };

  $scope.open2 = function() {
    $scope.popup2.opened = true;
  };

  $scope.setDate = function(year, month, day) {
    $scope.dt = new Date(year, month, day);
  };

  $scope.formats = ['dd-MMMM-yyyy', 'yyyy/MM/dd', 'dd.MM.yyyy', 'shortDate'];
  $scope.format = $scope.formats[0];
  $scope.altInputFormats = ['M!/d!/yyyy', 'ddMMyyyy'];

  $scope.popup1 = {
    opened: false
  };

  $scope.popup2 = {
    opened: false
  };

  var tomorrow = new Date();
  tomorrow.setDate(tomorrow.getDate()   1);
  var afterTomorrow = new Date();
  afterTomorrow.setDate(tomorrow.getDate()   1);
  $scope.events = [
    {
      date: tomorrow,
      status: 'full'
    },
    {
      date: afterTomorrow,
      status: 'partially'
    }
  ];

  function getDayClass(data) {
    var date = data.date,
      mode = data.mode;
    if (mode === 'day') {
      var dayToCheck = new Date(date).setHours(0,0,0,0);

      for (var i = 0; i < $scope.events.length; i  ) {
        var currentDay = new Date($scope.events[i].date).setHours(0,0,0,0);

        if (dayToCheck === currentDay) {
          return $scope.events[i].status;
        }
      }
    }

    return '';
  }
});
  

Комментарии:

1. где находится код?

2. почему бы вам не использовать формат, с которого вы хотите начать? Похоже, вы задаете проблемы, если пользователь решит изменить эту дату

3. когда вы выбираете дату, она должна быть в ‘ddMMyyyy’, вам не нужно событие ngchange!! я прав?

4. Я хочу ввести дату в этом формате ‘ddmmyyyyy’, и после этого я хочу, чтобы дата преобразовывалась в дд / ММ / гггг. Я просто не хочу показывать пустую маску. Может быть, я слишком усложняю эту задачу, но есть ли хороший способ сделать это?