使用AngularJS材质的AngularJS中的范围问题

时间:2017-06-21 17:46:06

标签: javascript angularjs angularjs-scope angular-material

我一直试图创建一个对话框,我可以在其中编辑一些信息。关键是你打开对话框,对话框中已经存在的东西,你可以编辑它然后保存它。我的问题是将信息从普通页面传递到对话框。以下是Controller的代码:

export class MainController {
    constructor ($scope, $log, $document, $mdDialog, demosService) {
        'ngInject';

        $scope.addDemo = function (name, html) {
            demosService.addDemo(name, html);
        };

        $scope.removeDemo = function (name, html) {
            demosService.removeDemo(name, html);
        };

        $scope.updateDemo = function (oldName, newName, html) {

        };

        $scope.getDemoInfo = function (name) {

        };

        $scope.getDemos = function () {
            return demosService.getDemos();
        };

        $scope.hide = function () {
            $mdDialog.hide();
        };

        $scope.cancel = function () {
            $mdDialog.cancel();
        };

        $scope.saveNew = function () {
            $scope.addDemo($scope.newdemo.name, $scope.newdemo.html);
            $scope.cancel();
        };

        $scope.loggle = function (log) {
            $log.log(log);
        }

        $scope.saveEdit = function (oldname) {
            //$scope.updateDemo($scope.demo.name, $scope.demo.newname, $scope.demo.newhtml);
            console.log($scope.oldname + ", " + $scope.newname + ", " + $scope.newhtml);
        };

        $scope.showNewDemo = function (ev) {
            $mdDialog.show({
                controller: MainController,
                template: "<form ng-cloak style='width: 800px'><md-toolbar><div class='md-toolbar-tools'><h2 style='color: #fff !important;'>New Demo</h2><span flex></span><md-button class='md-icon-button' ng-click='cancel()'>"
                +         "<i class='material-icons' style='color: #fff !important;'>clear</i></md-button></div></md-toolbar><md-dialog-content>"
                + "<div class='md-dialog-content'><md-input-container class='md-block'><label>Name</label><input ng-model='newdemo.name'></md-input-container></div><md-input-container class='md-block' style='padding-left: 25px; padding-right: 25px;'><label style='margin-left:25px; margin-bottom: 5px;'>HTML</label><textarea ng-model='newdemo.html' rows='5' md-select-on-focus></textarea></md-input-container ></md-dialog-content><md-dialog-actions layout='row'>"
+                         "<span flex></span><md-button ng-click='cancel()'>Cancel</md-button><md-button ng-click='saveNew()'>Save</md-button></md-dialog-actions></form>",
                parent: angular.element($document.body),
                targetEvent: ev,
                clickOutsideToClose: true,
                fullscreen: $scope.customFullscreen
            });
        };

        $scope.newname = "foo";
        $scope.newhtml = "bar";

        $scope.showEditDemo = function () {
            console.log($scope.newname + ", " + $scope.newhtml + ", " + $scope.oldname);
            $mdDialog.show({
                controller: MainController,
                template: "<form ng-controller='MainController' ng-cloak style='width: 800px'><md-toolbar><div class='md-toolbar-tools'><h2 style='color: #fff !important;'>Edit Demo</h2><span flex></span><md-button class='md-icon-button' ng-click='cancel()'>"
                + "<i class='material-icons' style='color: #fff !important;'>clear</i></md-button></div></md-toolbar><md-dialog-content>"
                + "<div class='md-dialog-content'><md-input-container class='md-block'><label>Name</label><input ng-model='newname'></md-input-container></div><md-input-container class='md-block' style='padding-left: 25px; padding-right: 25px;'><label style='margin-left:25px; margin-bottom: 5px;'>HTML</label><textarea ng-model='newhtml' rows='5' md-select-on-focus></textarea></md-input-container></md-dialog-content><md-dialog-actions layout='row'>"
                + "<span flex></span><md-button ng-click='cancel()'>Cancel</md-button><md-button ng-click='loggle()'>Save</md-button></md-dialog-actions></form>",
                parent: angular.element($document.body),
                targetEvent: ev,
                clickOutsideToClose: true,
                fullscreen: $scope.customFullscreen
            });
        };
    }
}

现在,$scope.newname = "foo";$scope.newhtml = "bar";有效,但问题是我需要通过范围函数来改变它们,即:

$scope.setVariables = function (name, html) {
    $scope.newname = name;
    $scope.newhtml = html;
}

如果您尝试从函数中console.log()那些变量,它们可以正常工作,但是从对话框内部,它将恢复为函数外部所描述的原始值。该功能是必需的,具有这些值的对话也是必要的。提前谢谢大家!

2 个答案:

答案 0 :(得分:0)

我有一个类似的场景并通过让当前控制器成为mdDialog的控制器来解决它。这是我使用的代码:

        var me = this
        this.$mdDialog.show({
            templateUrl: "components/listFilter/listFilterDialog.html",
            targetEvent: $event,
            parent: parentEl,
            controller: function () { return me },
            controllerAs: '$filterController',
            clickOutsideToClose: true,
            escapeToClose: true
        })

我没有使用$ scope,因为首先,这很糟糕。 :)如果你使用控制器或更好的组件,你将获得更多的里程数。

话虽如此,我想如果你使用类似的东西:

var thisScope = $scope
$mdDialog.show({
                controller: MainController,
                template: "...",
                locals: { data: thisScope}
                parent: angular.element($document.body),
                targetEvent: ev,
                clickOutsideToClose: true,
                fullscreen: $scope.customFullscreen
            });

我认为它会起作用或接近。这会将名为data的项注入到对话框的控制器中。然后你将在你的模板中绑定它。

答案 1 :(得分:0)

您可以通过服务传输数据。

例如,假设您在父页面和子页面中使用服务,请说myService

然后,您希望将一些数据从父控制器传递到子控制器,然后您可以将父控制器中的值设置为服务,如下所示:

myService.myObject=scope.myObject;

稍后您可以从服务访问子控制器中的同一对象,如下所示:

$scope.myObject=myService.myObject;

希望这有帮助