簡體   English   中英

在angular js中一次綁定數據

[英]Binding Data One time in angular js

就我而言,我有一個顯示某些數據的窗口。 每個$ window是單獨的,我可以在一段時間內擁有多個$ window,但不能使用相同的數據,當我打開第一個窗口時,所有細節都可以,但是一旦我打開下一個窗口並刷新了第一個窗口,就出現了問題將采用第二個窗口的值。

這里的JS打開窗口CockpitController

(function () {
    angular
        .module("cockpit", ['mm.foundation', 'security', 'message', 'isteven-multi-select', 'idCardSupplierWarn', 'idCardPartWarn', 'idCardSupplierInf'])
        .controller('cockpitController', ['$scope', '$translate', 'serviceCockpit', 'idCardSupplierWarnService', '$window', function ($scope, $translate, serviceCockpit, idCardSupplierWarnService, $window) {

            var urlSuppliersWarning = 'rest/suppliers/warnings';
            var urlSuppliersWarningByRefForDetails = 'rest/suppliers/warnings/supplier/ref/search';


            var self = this;

            serviceCockpit.loadData([urlSuppliersWarning]).then(function (results) {
                self.suppliersWarning = results[0].data;
            });

            this.change = function () {

                if (this.openWindow) {
                    this.openWindow = false;
                }
                else {
                    this.openWindow = true;
                }

            };


            $scope.openNewWindowRef = function (url, params) {
                console.log(params);
                idCardSupplierWarnService.setParam(params);
                console.log(idCardSupplierWarnService);
                var win = $window.open(url, '_blank', 'left=0, top=0, width=1100,height=600,scrollbars=yes, resizable=1');
                win.params = idCardSupplierWarnService.getParams();
            };

            $scope.openNewWindowSupp = function (url, params) {
                idCardSupplierWarnService.setParam(params);
                console.log(idCardSupplierWarnService);
                var win = $window.open(url, '_blank', 'left=0, top=0, width=1100,height=600,scrollbars=yes, resizable=1');
                win.params = idCardSupplierWarnService.getParams();
            };

            this.process = function (items) {

                if (items.origin == 'reference' || items.origin == 'suppliers' || items.origin == 'supplierAccounts' || items.origin == 'supplierAddressCodes' || items.origin == 'reset') {

                    serviceCockpit.loadData([urlSuppliersWarningByRefForDetails], items).then(function (results) {
                        self.suppliersWarningDetails = results[0].data;
                    });
                }

                serviceCockpit.loadData([urlSuppliersWarning], items).then(function (results) {
                    self.suppliersWarning = results[0].data;
                });
            }

        }]);
})();

窗戶控制器

(function () {
    angular
        .module("idCardSupplierWarn", ['mm.foundation', 'security', 'message', "isteven-multi-select", 'cockpit'])
        .controller('idCardSupplierWarnController', ['$translate', '$scope', 'serviceCockpit', 'idCardSupplierWarnService', '$window', function ($translate, $scope, serviceCockpit, idCardSupplierWarnService, $window) {


            var urlSupplierWarningByRefDetail = 'rest/suppliers/warnings/supplier/details';

            var self = this;
            console.log(self.params);
            if (typeof self.params == 'undefined') {
                var params = $window.parent.params;
                self.params = params;
                serviceCockpit.loadData([urlSupplierWarningByRefDetail], params).then(function (results) {
                    self.suppliersWarningsList = results[0].data;
                });

            }


        }]);
})();

窗口HTML:

<div class="main-content" ng-controller="idCardSupplierWarnController as cpt">



    <section class="top-bar" id="main-menu">
        <div class="menu-text"><span class="txt-white"> <center><h5 style="color #FFCC33">{{ 'ID_CARD_SUPPLIER_HOME' | translate }}</h5></center></span>
        </div>
        <div>
            <center>
                <ul class="menu">
                    <ul class="menu">
                        <li ng-class="getClass('/idCardSupplierInf/id/code')"><a href="#/idCardSupplierInf/id/code">{{
                            'ID_CARD_SUPPLIER_HOME_INF' | translate }}</a></li>
                        <li ng-class="getClass('/idCardSupplierGraph')"><a href="#/idCardSupplierGraph" >{{ 'ID_CARD_SUPPLIER_HOME_GRAPH' | translate }}</a></li>
                        <li ng-class="getClass('/idCardSupplierWarn')"><a  href="#/idCardSupplierWarn" >{{ 'ID_CARD_SUPPLIER_HOME_WARN' | translate }}</a></li>

                    </ul>
                </ul>
            </center>
        </div>
    </section>

    <br>
    <div class="row">
        <div class="small-12 large-12 columns maintitle-id">
            <h1>{{ 'ID_CARD_PART_WARN_TITLE_REF' | translate }} {{cpt.params.idSupNum}}.{{cpt.params.codeSuppNum}}</h1>
        </div>
    </div>
    <br/>


    <div class="row">
        <div class="small-12 medium-12 large-12 text-center columns">
            <div class="callout medium shadowd">

                <table>
                    <thead>
                    <tr>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_REF' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_DES' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_GR' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_HOME_TAB1_CODE' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_STOCK' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_CO' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_RE' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_LATE' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_OLD' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_BO' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_VOR' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_QTY1' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_DELAY1' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_CAUSE' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_WARN' | translate }}</th>
                        <th>{{ 'ID_CARD_SUPPLIER_WARN_TAB_ACTION' | translate }}</th>

                    </tr>
                    </thead>
                    <tbody>
                    <tr ng-repeat="sup in cpt.suppliersWarningsList">

                        <td><a>{{sup.designRefPart}}</a></td>
                        <td>{{sup.labelRefPart}}</td>
                        <td>{{sup.grpes}}</td>
                        <td>{{sup.idSuppNumber}}.{{sup.codeSupp}}</td>
                        <td>{{sup.stock}}</td>
                        <td>{{sup.couvrage}}</td>
                        <td>{{sup.remaingToDeliver}}</td>
                        <td>{{sup.delaySupp}}</td>
                        <td>{{sup.durationDelay}}</td>
                        <td>{{sup.bo}}</td>
                        <td>{{sup.vor}}</td>
                        <td>{{sup.quantity}}</td>
                        <td>{{sup.delaySupp}}</td>
                        <td>{{sup.alfCause}}</td>
                        <td>{{sup.alertMsg}}</td>
                        <td>{{sup.actionMsg}}</td>

                    </tr>
                    </tbody>
                </table>
            </div>
        </div>

    </div>
















</div>

這是雙向數據綁定的功能 。使用angular.copy()進行源的深層復制。 然后,該變量/作用域不更新其父值。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM