簡體   English   中英

md對話框中的md-autocomplete失去對onclick的關注

[英]md-autocomplete in md-dialog loses focus onclick

我正在使用AngularJS 1.6和Angular Material,我有一個md-autocomplete ,它曾經可以正常工作,但是在將它放在md-dialog框中后,它的工作情況不再那么好了。 每當我單擊自動完成字段時, 焦點就會立即消失並且我無法填寫輸入。(或者您必須非常快地寫一封信,然后焦點才會消失)。

我試圖在單擊,焦點和鍵入上執行event.stopPropagation() ,但沒有幫助。 我想了一下,兩個控制器的作用域處於限制狀態,因此我刪除了兩個作用域之間的鏈接,但沒有幫助。 我搜索了一下,似乎以前沒有人喜歡過。

這是觸發md-dialog的代碼:

    public showAddAuthDialog(ev: any) {

        this.$mdDialog.show({
            controller: AddJobAuthDialogController,
            controllerAs: "AddAuthDialog",
            templateUrl: 'public/app/views/dialogs/addAuthDialog.html',                
            targetEvent: ev,                
            clickOutsideToClose: true,
            fullscreen: this.customFullscreen,
            scope: this.$scope,
            preserveScope:true            
        });
    }    

注意:我通過了范圍來保留數據,我認為這是問題所在,因此我將其刪除,但未進行任何更改。

這是對話框控制器的代碼:

     export class AddJobAuthDialogController {
         static $inject = ['$scope','$mdDialog',
              '$timeout',
                '$q',
                 'jobService'];
         public simulateQuery: boolean;
         public selectedItem: any;
         public selectedItemId: string;
         public searchTxt: string;      
         public jobsToSearch: any;            
         public selectedItemAD: any;
         public searchTxtAD: string;            
         public grpsToSearch: any;
         public customFullscreen = false;



    constructor(public $scope: any,
        public $mdDialog: any,
        public $timeout: any,
        public $q: any,
        public jobService: jobs.IJobService) {

        this.simulateQuery = true;
        this.selectedItem = null;
        this.searchTxt = null;
        this.selectedItemAD = null;
        this.searchTxtAD = null;

        this.jobsToSearch = this.$scope.Administration.jobsToSearch;
        this.grpsToSearch = this.$scope.Administration.grpsToSearch;

    }

    public $onChanges(changes) {
        if (changes.selectedItem) {
            this.selectedItem = changes.selectedItem.currentValue;
        }
        if (changes.jobsToSearch) {
            this.jobsToSearch = changes.jobsToSearch.currentValue;
        }
        if (changes.selectedItemId) {
            this.selectedItemId = changes.selectedItemId.currentValue;
        }
        if (changes.grpsToSearch) {
            this.grpsToSearch = changes.grpsToSearch.currentValue;
        }
    }

    public sendForm(event: any) {
        this.jobService.saveNewEntry(this.selectedItem.value, this.selectedItemAD.value).then((d) => {
            console.log(d);
            if (d.data == -1)
                this.showError(event);
            else
                this.showSuccess(event);
        });
    }

    public showSuccess(ev: any) {
        this.$mdDialog.show({
            controller: InsertDialogController,
            controllerAs: "InsertDialog",
            templateUrl: 'public/app/views/dialogs/adminInsertSuccessDialog.html',
            parent: angular.element(document.body),
            targetEvent: ev,
            clickOutsideToClose: true,
            fullscreen: this.customFullscreen // Only for -xs, -sm breakpoints.
        });
    };

    public showError(ev: any) {
        this.$mdDialog.show({
            controller: InsertDialogController,
            controllerAs: "InsertDialog",
            templateUrl: 'public/app/views/dialogs/adminInsertFailDialog.html',
            parent: angular.element(document.body),
            targetEvent: ev,
            clickOutsideToClose: true,
            fullscreen: this.customFullscreen // Only for -xs, -sm breakpoints.
        });
    };

    public querySearch(query, objectToSearch) {
        var results = query ? objectToSearch.filter(this.createFilterFor(query)) : objectToSearch,
            deferred;
        if (this.simulateQuery) {
            deferred = this.$q.defer();
            this.$timeout(function () { deferred.resolve(results); }, Math.random() * 1000, false);
            return deferred.promise;
        } else {
            return results;
        }
    }

    public createFilterFor(query) {
        var lowercaseQuery = angular.lowercase(query);
        return (res) => {
            return (angular.lowercase(res.display).indexOf(lowercaseQuery) !== -1);
        };
    }

    public cancelDialog() {
        this.$mdDialog.cancel();
    }
}

這是html模板:

    <md-dialog class="dialogSuccess" aria-label="Add Groups To Job">

    <md-toolbar>
        <div class="md-toolbar-tools">
            <h2>Add Groups To Job</h2>
            <span flex></span>
            <md-button class="md-icon-button" ng-click="AddAuthDialog.cancelDialog()">
                <md-icon class="closeIcon" md-font-icon="mdi mdi-close" aria-label="Close dialog"></md-icon>
            </md-button>
        </div>
    </md-toolbar>

    <md-content layout="column" flex ng-cloak>
        <div class="md-dialog-content">
            <form>
                <md-autocomplete flex
                                 md-input-name="autocompleteField"
                                 md-input-minlength="0"
                                 md-input-maxlength="18"
                                 md-no-cache="true"
                                 md-selected-item="AddAuthDialog.selectedItem"
                                 md-search-text="AddAuthDialog.searchTxt"
                                 md-items="item in AddAuthDialog.querySearch(AddAuthDialog.searchTxt,AddAuthDialog.jobsToSearch)"
                                 md-item-text="item.display"                                                                                        
                                 md-floating-label="Jobs">
                    <md-item-template>
                        <span md-highlight-text="AddAuthDialog.searchTxt">{{item.display}}</span>
                    </md-item-template>
                    <md-not-found>Job "{{AddAuthDialog.searchTxt}}" not found </md-not-found>
                </md-autocomplete>

                <md-autocomplete flex
                                 md-input-name="autocompleteFieldAD"
                                 md-input-minlength="3"
                                 md-input-maxlength="18"
                                 md-no-cache="true"
                                 md-selected-item="AddAuthDialog.selectedItemAD"
                                 md-search-text="AddAuthDialog.searchTxtAD"
                                 md-items="i in AddAuthDialog.querySearch(AddAuthDialog.searchTxtAD,AddAuthDialog.grpsToSearch)"
                                 md-item-text="i.display"
                                 md-floating-label="AD Groups">
                    <md-item-template>
                        <span md-highlight-text="AddAuthDialog.searchTxtAD">{{i.display}}</span>
                    </md-item-template>
                    <md-not-found>Job "{{AddAuthDialog.searchTxtAD}}" not found </md-not-found>
                </md-autocomplete>

            </form>
        </div>
    </md-content>


<md-dialog-actions>
    <md-button class="md-raised md-primary md-hue-1" ng-click="AddAuthDialog.sendForm()">Add</md-button>
</md-dialog-actions>

 </md-dialog>

注意:有一會兒我以為問題是浮動標簽,因為我在控制台中收到以下警告:

mdInput消息顯示在無效消息元素上調用的動畫:JQLite [md-input-container.ng-scope.md-input-focused.md-input-has-value.ng-animate.md-input-invalid]

然后我刪除了它,而是放了一個占位符,但是行為沒有改變。 有什么問題可能出在哪里?

更新:

似乎失去了焦點,因為它重新聚焦在已單擊的按鈕上,如果我取消了按鈕的聚焦,頁面上的每個事件都將不再觸發。

這是按鈕的html代碼:

      <div class="fab-container" layout="row" layout-align="end end">
    <md-fab-speed-dial md-open="false" md-direction="up"
                       ng-class="md-fling">
        <md-fab-trigger ng-click="Administration.showAddAuthDialog($event)" ng-focus="false">
            <md-button aria-label="menu" class="md-fab md-accent">
                <md-icon class="mdi mdi-plus fab-button-icon"></md-icon>
            </md-button>
        </md-fab-trigger>          
    </md-fab-speed-dial>
</div>

看來問題出在md-fab-speed-dial,無論出於何種原因,它都始終保持着焦點。 我只是用一個簡單的按鈕替換了整個內容,現在一切正常。

新的html:

    <div layout="row" layout-align="end end">       
            <md-button  ng-click="Administration.showAddAuthDialog($event)" aria-label="menu" class="md-fab md-accent">
                <md-icon class="mdi mdi-plus fab-button-icon"></md-icon>                    
            </md-button>          
</div>

暫無
暫無

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

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