ui-bootstrapコンポーネントを使用してモーダル内に日付ピッカーを作成しようとしています。 datepickerは、unixタイムスタンプとしてフォーマットされた日付を返さなければなりません。モーダル内のdatepickerが機能しない
日付ピッカーをモーダル内にない場合、これは(=タイムスタンプの更新日付が選択されている場合)正常に動作している:http://plnkr.co/edit/9zHQQPGAcomT5Vha33j3?p=preview
:
http://plnkr.co/edit/xQFmVgJojiq6aG9U8f4H?p=preview
そして、私は、モーダル内のディレクティブを置きますここ
はコントローラである:
.controller('MyCtrl', [ '$scope', '$modal', function ($scope, $modal) {
$scope.open = function() {
var modalInstance = $modal.open({
templateUrl: 'tplModal.html',
controller: 'MyModalCtrl'
});
};
}])
.controller('MyModalCtrl', [ '$scope', '$modalInstance', function ($scope, $modalInstance) {
$scope.required= {};
$scope.disabled = function(date, mode) {
return (mode === 'day' && (date.getDay() === 0 || date.getDay() === 6));
};
$scope.minDate = new Date();
$scope.$watch('dt', function() {
if ($scope.dt) $scope.required.timestamp = Math.floor($scope.dt.getTime()/1000);
console.log('timestamp: ', $scope.required.timestamp, '/ dt: ', $scope.dt);
});
$scope.cancel = function() {
$modalInstance.dismiss('cancel');
};
}]);
とモーダルのHTMLテンプレート:日付が変更されたときにタイムスタンプが更新されません。この第二版では
<div class="modal-body">
<div ng-model="dt">
<datepicker min="minDate" show-weeks="false"></datepciker>
</div>
<div>
dt <span class="uneditable-input span2">{{dt | date:'dd.MM.yyyy' }}</span>
dt <span class="uneditable-input span2">{{ dt }}</span>
timestamp <span class="uneditable-input span2">{{ required.timestamp }}</span>
</div>
</div>
(それは時計が働いていなかった$のようなものです)。
この方法を知っていますか?
あなたが範囲の問題に遭遇していると推測しなければならない場合は、ここでモーダルはコントローラのサブスコープを作成します。私はng-includeを使ってこれに遭遇しました。あなたのdtがどこに定義されているのか分かりません。私の解決策は私の「単純な価値」をコントローラーのオブジェクトに入れてサブスコープでアクセスできるようにすることでした。 [単純な性質は継承されなかった。オブジェクトは]。 – JeffryHouser