繁体   English   中英

无法以角度访问控制器内部的变量

[英]Cannot access a variable inside controller in angular

我正在尝试在我的角度演示项目中实现Crop插件库 我已经将所需的模块注入到我的主模块中,并成功裁剪了一张照片。 但是我不知道如何将base64字符串传递给控制器​​。 到目前为止,我尝试过的是:

var myApp = angular.module('myModule', ['ngRoute', 'angular-img-cropper', 'app']);

myApp.config(function($routeProvider) {
        $routeProvider
            .when('/multiple',{
                    templateUrl: 'templates/multi.html',
                    controller: 'multiController',
                    controllerAs: 'multiCtrl'           
            })
});

myApp.controller('multiController', function ($scope,$rootScope) {
        var vm = this;
        vm.clickButton = function () {
            console.log("photo: "+vm.member_photo);
        };
});

HTML-templates / multi.html:

<h1>Multi page which has another controller inside</h1>
<div ng-controller="multiController">
    <div ng-controller="ImageCropperCtrl as ctrl">
    <input type="file" img-cropper-fileread image="cropper.sourceImage"   />
    <div>
      <canvas width="500" height="300" id="canvas" image-cropper image="cropper.sourceImage" cropped-image="cropper.croppedImage" crop-width="500" crop-height="200" min-width="100" min-height="50" keep-aspect="true" crop-area-bounds="bounds"></canvas>
    </div>
    <div>Cropped Image (Left: {{bounds.left}} Right: {{bounds.right}} Top: {{bounds.top}} Bottom: {{bounds.bottom}})</div>
    <div ng-show="cropper.croppedImage!=null"><img ng-model="member_photo1" ng-src="{{cropper.croppedImage}}" /></div>
        <textarea name="member_photo" ng-model="multiCtrl.member_photo" id="member_photo" class="form-control valid">{{cropper.croppedImage}}</textarea>
    </div>
  <button ng-controller="insideController" ng-click="multiCtrl.clickButton()">Console.log</button>
</div>

如果我检查了textarea,则该值存在,但未在textarea中显示,并且该值也无法在控制器内部访问。 我究竟做错了什么?

正如@Taylor Buchanan指出的那样,您的代码存在多个问题。 我也建议您阅读Angular文档和示例。

除了@Taylor Buchanan指出的问题外,我可以看到您在模板中使用了3个不同的控制器。 multiControllerImageCropperCtrlinsideController 我不明白为什么需要那么多控制器。

另外,您在textarea不需要单独的ng-model。

考虑到您的需求,我认为一个控制器就足够了。 这里是示例代码@ plunker ,它显示了如何使用图像裁剪器以及如何在控制器中获取裁剪后的图像数据。

script.js

angular.module('myApp', ['angular-img-cropper']);

angular.module('myApp').controller("multiController",[ '$scope', function($scope)
{
    $scope.cropper = {};
    $scope.cropper.sourceImage = null;
    $scope.cropper.croppedImage   = null;
    $scope.bounds = {};
    $scope.bounds.left = 0;
    $scope.bounds.right = 0;
    $scope.bounds.top = 0;
    $scope.bounds.bottom = 0;

    $scope.clickButton = function () {
        console.log("photo: "+ $scope.cropper.croppedImage);
    };
}]);

index.html

<!DOCTYPE html>
<html>

  <head>
    <script data-require="jquery@2.2.4" data-semver="2.2.4" src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
    <link rel="stylesheet" href="style.css" />
  </head>

  <body ng-app="myApp" ng-controller="multiController">
    <h1>Image Cropper Demo</h1>
    <div>
      <input img-cropper-fileread="" image="cropper.sourceImage" type="file" />
      <div>
        <canvas width="500" height="300" id="canvas" image-cropper="" image="cropper.sourceImage" cropped-image="cropper.croppedImage" crop-width="400" crop-height="200" keep-aspect="true" touch-radius="30" crop-area-bounds="bounds"></canvas>
      </div>
      <div>Cropped Image (Left: {{bounds.left}} Right: {{bounds.right}} Top: {{bounds.top}} Bottom: {{bounds.bottom}})</div>
      <div ng-show="cropper.croppedImage!=null">
        <img ng-src="{{cropper.croppedImage}}" />
      </div>
      <textarea name="member_photo" id="member_photo" class="form-control valid">{{cropper.croppedImage}}</textarea>
      <button ng-click="clickButton()">Console.log</button>
    </div>

    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.js"></script>
    <script src="angular-img-cropper.min.js"></script>
    <script src="script.js"></script>
  </body>

</html>

注意:由于我没有使用路由提供程序,因此必须在主体级别显式指定ng-controller 使用路由提供程序时,无需在模板中指定ng-controller 查看$ route给出的示例

您必须在模板中指定回调函数,并在控制器中实现裁剪回调函数。 例如 :

在模板中:

crop-callback="myCallbackFunction"

在控制器中:

vm.myCallbackFunction = function(base64) {
  vm.resultImage = base64;
  $scope.$apply(); // Apply the changes.
};

您遇到各种各样的问题,主要是由于复制和粘贴库示例而引起的。 如果您是Angular的新手,我强烈建议您在实施任何其他库之前,先阅读Angular 文档示例 话虽这么说,这里有一些问题:

  1. 您正在引用模板中未定义的控制器。 ImageCropperCtrl是示例中定义的控制器,但不是您提供的代码中定义的控制器。

     <div ng-controller="ImageCropperCtrl as ctrl"> 

    由于您已经创建了自己的控制器,因此可以将其删除。

  2. 您正在整个控制器中引用未在控制器中定义的名为cropper的对象。 您可以在示例中看到他们在使用对象之前在ImageCropperCtrl控制器中声明该对象的情况:

     $scope.cropper = {}; 

    在控制器中声明了此变量后,您将可以使用$scope.cropper.croppedImage访问裁剪的图像。

  3. 您试图在整个模板multiCtrl控制器作为multiCtrl 仅在将控制器用作语法时才有效(类似于库示例中显示的内容: ImageCropperCtrl as ctrl )。

     <div ng-controller="multiController"> 

    会成为:

     <div ng-controller="multiController as multiCtrl"> 
  4. 您正在将ng-model和插值( {{}} )用于textarea 您可能只想使用ng-model ,但是我不太确定您要在这里做什么。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM