做網(wǎng)站經(jīng)常會遇到彈出對話框獲取用戶輸入或彈出對話框讓用戶確認某個操作之類的情景,有一個基于AngularJS的擴展模塊可以幫我們優(yōu)雅地完成這類事情:ngDialog。
在亭湖等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供網(wǎng)站建設、成都做網(wǎng)站 網(wǎng)站設計制作按需求定制設計,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,成都品牌網(wǎng)站建設,營銷型網(wǎng)站建設,成都外貿(mào)網(wǎng)站建設,亭湖網(wǎng)站建設費用合理。
ngDialog在github上提供了一個示例網(wǎng)頁,演示了它的各種用法,在這里:https://github.com/likeastore/ngDialog/blob/master/example/index.html。ngDialog的github主頁的readme也對常用的指令和服務做了較為詳細的介紹,可以參考。我這篇就純粹是參考ngDialog的示例來的。
創(chuàng)建對話框可以是用ngDialog.open(options)或ngDialog.openConfirm(options)。前者打開一個普通的對話框,可以通過options制定諸如主題、模板等一系列屬性,后者打開一個默認拒絕escape關閉和點擊對話框之外自動關閉的對話框。options是json對象,類似下面:
{template: 'tplId',closeByEscape: false}
示例搭建
先看下我的簡單示例。使用express generator創(chuàng)建一個新應用,或者直接使用Node.js開發(fā)入門——使用cookie保持登錄里的LoginDemo示例。都成。
添加自己寫的文件
有三個自己寫的文件,ngdialog.html和serverTpl.html文件放在項目的public目錄下,ngdialog.js放在public/javascripts下面。
ngdialog.html內(nèi)容:
use ngDialog in AngularJS
ngdialog.js內(nèi)容:
angular.module('myApp', ['ngDialog']). controller('myController', function($scope,$rootScope, ngDialog){ $scope.template = 'text in dialog
'; //different template $scope.openDialog = function(){ ngDialog.open({template: 'firstDialogId'}); }; $scope.openPlainDialog = function(){ ngDialog.open({ template: 'firstDialogId', //use template id defined in HTML className: 'ngdialog-theme-plain' }); } $scope.openDialogUseText = function(){ ngDialog.open({ template: $scope.template, //use plain text as template plain: true, className: 'ngdialog-theme-plain' }); } $scope.openModal = function(){ ngDialog.open({ template: 'Text in Modal Dialog
', plain: true, className: 'ngdialog-theme-default', closeByEscape: false, closeByDocument: false }); } $scope.openUseExternalTemplate = function(){ ngDialog.open({ template: 'serverTpl.html', plain: false, className: 'ngdialog-theme-default', closeByEscape: false, closeByDocument: false }); }; $rootScope.userName = "ZhangSan"; $scope.openConfirmDialog = function(){ ngDialog.openConfirm({ template: ' ', plain: true, className: 'ngdialog-theme-default' }).then( function(value){ console.log('confirmed, value - ', value); }, function(reason){ console.log('rejected, reason - ', reason); } ); } //listen events $rootScope.$on('ngDialog.opened', function (e, $dialog) { console.log('ngDialog opened: ' + $dialog.attr('id')); }); $rootScope.$on('ngDialog.closed', function (e, $dialog) { console.log('ngDialog closed: ' + $dialog.attr('id')); }); });serverTpl.html內(nèi)容:
A Server Template for ngDialog Server Template for ngDialog
Node.js Express AngularJS MongoDB 引入ngDialog
要使用ngDialog,需要在HTML中使用script引入對應的js庫文件。另外還要在head部分引入幾個css文件。參考ngdialog.html即可。
ngDialog的庫文件可以到https://github.com/likeastore/ngDialog下載,或者到這里下載:http://cdnjs.com/libraries/ng-dialog。我是在后面這個鏈接下的0.4.0版本,把文件重命名了一下。重命名后的幾個文件如下:
- ngDialog-0.4.0.min.js
- ngDialog-0.4.0.min.css
- ngDialog-theme-default-0.4.0.min.css
- ngDialog-theme-plain-0.4.0.min.css
API摘要學習
我學習時遇到了一些疑惑,記錄在下面。
對話框內(nèi)容模板
要顯示一個對話框,必須得指定待現(xiàn)實的內(nèi)容。這是通過template屬性指定的。template有三種情況:
- 嵌入在js或html代碼里的純文字模板,此時需要同時在options里設置plain屬性為true,即“plain:true”,然后直接將一段html代碼賦值給template,比如template:
Text in ngDialog
- 在HTML內(nèi)定義template模板,同時給模板指定id,將id賦值給template選項,比如“template: ‘templateId'”。而模板可能是這樣的:
- 以外部的html片段(文件)為模板,比如“template: ‘serverTpl.html'”,serverTpl.html文件在服務器上。
指定主題
可以在options里通過className指定主題,目前有ngdialog-theme-default和ngdialog-theme-plain兩個主題。這兩個注意對應兩個css文件,前面我們已經(jīng)通過HTML引入了。
響應關閉等事件
對話框被關閉時,會發(fā)出一些事件,開發(fā)者可以監(jiān)聽這些事件來獲得通知。具體事件有:
- ngDialog.opened
- ngDialog.closing
- ngDialog.closed
這些事件定義在$rootScope服務里,所以我們的controller構造函數(shù)必須依賴$rootScope。比如我們現(xiàn)在的模塊定義和controller定義:
angular.module(‘myApp', [‘ngDialog']). controller(‘myController', function(scope,scope,rootScope, ngDialog){在模塊定義里注明依賴ngDialog模塊,在controller定義里注入了$rootScope和ngDialog。
如何監(jiān)聽事件,看ngdialog.js代碼吧。
另外我們還可以在options中設置preCloseCallback,指定一個函數(shù),這個函數(shù)在對話框取消關閉之前會調用到。https://github.com/likeastore/ngDialog這里有說明。注意,是取消對話框時會調用到,如果確認,不會調到哦。所以,這個preCloseCallback通常在阻止或提醒用戶放棄輸入時使用,比如用戶注冊,輸入了一些信息,想退,你可以問他是否要真的想放棄。
指定對話框的controller
可以通過options設置controller屬性來給一個對話框指定控制器。這個控制器可以是內(nèi)聯(lián)(inline)的:
$scope.openInlineController = function () { $rootScope.theme = 'ngdialog-theme-plain'; ngDialog.open({ template: 'withInlineController', controller: ['$scope', '$timeout', function ($scope, $timeout) { var counter = 0; var timeout; function count() { $scope.exampleExternalData = 'Counter ' + (counter++); timeout = $timeout(count, 450); } count(); $scope.$on('$destroy', function () { $timeout.cancel(timeout); }); }], className: 'ngdialog-theme-plain' }); };也可以是在js中定義的。比如我們在js里定義了一個名為“InsideCtrl”的controller,就可以在調用ngDialog.open(options)時在options里設置controller屬性:
$scope.openInsideController = function(){ ngDialog.open({ template: "serverTpl.html", className: "ngdialog-theme-plain", controller: "InsideCtrl" }); };具體示例可以參考:https://github.com/likeastore/ngDialog/blob/master/example/index.html。
確認對話框
比如讓用戶確認刪除,讓用戶輸入。使用openConfirm(options)就可以創(chuàng)建這樣的對話框。ngDialog向$scope注入了兩個函數(shù),一個是confirm(value),一個是closeThisDialog(reason),分別用來確認關閉對話框,取消關閉對話框。將它們關聯(lián)到確認和取消按鈕上,就可以確認、取消對話框。
假如我要讓用戶輸入用戶名,可以用ng-model指令將作用域內(nèi)某個變量和input綁定,在調用confirm時傳入綁定的變量,這樣就可以在confirm中拿到用戶填寫的值來做進一步處理。我們的示例中的openConfirmDialog按鈕,點擊后就彈出一個讓用戶輸入名字的對話框,當用戶輸入完畢,點擊Confirm按鈕時,我們可以通過confirm方法的value參數(shù)獲得用戶名輸入框的值。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
當前題目:Node.js使用對話框ngDialog的示例代碼
文章位置:http://weahome.cn/article/igspgp.html