angular.js - controller层的方法读取到的数组赋值给$scope下的对象,该对象绑定到了页面上,为什么页面上看不到数组中的内容
PHP中文网
PHP中文网 2017-05-15 16:57:30
0
2
640

appCtrls.controller('uploadFileCtrl', function ($scope, $state, $cordovaImagePicker, localStorageService) {

$scope.initPage = function () {
    $scope.folderName=""
    $scope.fileList = [];
}
$scope.chooseFile = function () {
    var options = {
        maximumImagesCount: 9,
        width: 800,
        height: 800,
        quality: 80
    };
    $cordovaImagePicker.getPictures(options).then(function (results) {
        $scope.fileList=results;
        console.log("fileList:"+$scope.fileList);
    }, function (error) {
        // error getting photos
    });
}

})

//页面
<form name="fileForm" novalidate>
<ion-view>

<ion-nav-buttons side="left">
    <a class="button button-clear" ui-sref="tab.more-userInfo"><i class="icon ion-ios-arrow-left"></i></a>
</ion-nav-buttons>
<ion-nav-buttons side="right">
    <a class="button button-clear" ng-click="uploadFiles()">发送</a>
</ion-nav-buttons>
<ion-content ng-init="initPage()">
    <script id="templates/form-errors.html" type="text/ng-template">
        <p class="form-error" ng-message="ng-maxlength">请输入最多20个字符</p>
        <p class="form-error" ng-message="ng-minlength">请输入至少1个字符</p>
    </script>

    <p class="item item-input" ng-class="{'has-error':fileForm.folderName.$invalid}">
        <textarea style="height: 100px" ng-model="folderName" name="folderName" type="text" placeholder="请输入文档名称" ng-maxlength="20" ng-minlength="1">
        </textarea>
    </p>
    <p ng-show="fileForm.folderName.$invalid" class="form-errors"
         ng-messages="fileForm.folderName.$error"
         ng-messages-include="templates/form-errors.html">
    </p>
    <p class="item item-icon-left">
        <i ng-click="chooseFile()" class="icon ion-image" style="width: 30px;height:26px"></i>
    </p>
    <p class="row">
        <p class="item-avatar" ng-repeat="file in fileList">
            <img ng-src="{{file}}">
        </p>
    </p>
</ion-content>

</ion-view>
</form>
getPictures方法返回一个字符串数组,该字符串数组每一个元素都是一个文件路径,然后将图片显示到页面上,可是结果是什么也看不到,这是怎么回事呢

PHP中文网
PHP中文网

认证0级讲师

全員に返信(2)
大家讲道理

$scope.$digest();

を $scope.fileList=results; の下に追加してください。

通常、ng-click などのイベント関数は実行後、スコープが変更されたかどうかを自動的に検出し、変更を適用します。ただし、ここでは非同期操作を実行するために Promise を使用しており、then() 内の関数は非同期操作の完了後に実行されます。この時点ではchooseFileが実行されており、digestを呼び出さない限り変更は自動検出されません。

つまり、Angular が非同期操作、サードパーティ イベント、他のコントローラーへの変更などの変更を自動的に検出する場合、多くの例外が発生するため、$scope.$digest();

を追加するように注意してください。
いいねを押す +0
左手右手慢动作
  1. テンプレート内のカスタム命令は通常どおり使用できます。

  2. コントローラーがテンプレートに正常に登録されました。
    上記の 2 つの項目が当てはまる場合、前述したように、テンプレートのレンダリングが完了する前にコールバック関数が正常に返されないため、返されたデータを取得できません。

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート