На главной странице списка есть кнопка редактирования. Это открывает детали отредактированной строки.
Путь-1: Теперь, если я установил "ctrl.parent.q_details.client_location", он связывается с родительским листинговым контроллером и работает как двусторонняя привязка и автоматически изменяет значения, как в поле редактирования изменения, которые здесь не являются обязательными.
Здесь просто я хочу отображать и разрешать значения редактирования в поле ввода. Не хотите меняться в родительском контроллере.
► Ниже приведен код в родительском контроллере для вызова mdDialog
$mdDialog.show({
locals:{parent: $scope},
clickOutsideToClose: true,
controllerAs: 'ctrl',
templateUrl: 'quotation/edit/',//+edit_id,
controller: function () { this.parent = $scope; },
});
► Ниже приведен код всплывающего окна mdDialog.
<md-dialog aria-label="">
<div ng-app="inputBasicDemo" ng-controller="deliverController" layout="column">
<form name="" class="internal_note_cont">
<md-content class="md-padding">
<md-input-container class="md-input-has-value" flex>
<label>Client Name</label>
<input ng-model="qe.client_name" required >
</md-input-container>
<md-input-container flex>
<label>Client Location</label>
<input required ng-model="ctrl.parent.q_details.client_location">
</md-input-container>
</md-content>
</form>
<div>
</div>
</div>
<input type="" required ng-model="ctrl.parent.q_details.recid">
</md-dialog>
Way2: второй способ отправляет значение непосредственно из БД без привязки к ng-модели контроллера Dialog (deliverController).
]).controller("deliverController", ["$scope", "$filter","$http","$route","$window","$mdDialog",
function ($scope, $filter,$http,$route,$window,$mdDialog) {
$scope.qe.client_name = '12345'; // just to test.
}
Это дает ошибку undefine $scope.qe.
Так что, в конечном счете, я не могу отправлять данные в mdDialogue и отображать их и разрешать их редактировать как обычный.
Пожалуйста, любой опытный парень angular мне поможет. Я новичок в angular.
Я делаю разные способы с 2 дней.