亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

Node.js使用對話框ngDialog的示例代碼

2024-05-06 16:44:13
字體:
來源:轉載
供稿:網友

做網站經常會遇到彈出對話框獲取用戶輸入或彈出對話框讓用戶確認某個操作之類的情景,有一個基于AngularJS的擴展模塊可以幫我們優雅地完成這類事情:ngDialog。

ngDialog在github上提供了一個示例網頁,演示了它的各種用法,在這里:https://github.com/likeastore/ngDialog/blob/master/example/index.html。ngDialog的github主頁的readme也對常用的指令和服務做了較為詳細的介紹,可以參考。我這篇就純粹是參考ngDialog的示例來的。

創建對話框可以是用ngDialog.open(options)或ngDialog.openConfirm(options)。前者打開一個普通的對話框,可以通過options制定諸如主題、模板等一系列屬性,后者打開一個默認拒絕escape關閉和點擊對話框之外自動關閉的對話框。options是json對象,類似下面:

{template: 'tplId',closeByEscape: false}

示例搭建

先看下我的簡單示例。使用express generator創建一個新應用,或者直接使用Node.js開發入門——使用cookie保持登錄里的LoginDemo示例。都成。

添加自己寫的文件

有三個自己寫的文件,ngdialog.html和serverTpl.html文件放在項目的public目錄下,ngdialog.js放在public/javascripts下面。

ngdialog.html內容:

<!doctype html><html ng-app="myApp"><head> <title>use ngDialog in AngularJS</title> <link rel='stylesheet' href='/stylesheets/ngDialog-0.4.0.min.css' ><link/> <link rel='stylesheet' href='/stylesheets/ngDialog-theme-default-0.4.0.min.css' ><link/> <link rel='stylesheet' href='/stylesheets/ngDialog-theme-plain-0.4.0.min.css' ><link/></head><body ng-controller='myController'> <p><button type='button' ng-click='openDialog()'>Open Default</button></p> <p><button type='button' ng-click='openPlainDialog()'>Open Plain theme</button></p> <p><button type='button' ng-click='openDialogUseText()'>Open use text</button></p> <p><button type='button' ng-click='openModal()'>Open modal</button></p> <p><button type='button' ng-click='openUseExternalTemplate()'>Open use template on server</button></p> <p><button type='button' ng-click='openConfirmDialog()'>Open Confirm</button></p> <script src="/javascripts/angular-1.4.3.min.js"></script> <script src="/javascripts/ngDialog-0.4.0.min.js"></script> <script src="/javascripts/ngdialog.js"></script> <!-- Templates --> <script type="text/ng-template" id="firstDialogId">  <div><p>text in dialog</p></div> </script></body></html>

ngdialog.js內容:

angular.module('myApp', ['ngDialog']). controller('myController', function($scope,$rootScope, ngDialog){  $scope.template = '<div><p>text in dialog</p><p><button type="button">Button</button></p><div>';  //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: '<p>Text in Modal Dialog</p>',    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: '<div class="ngdialog-message"><h3>Please enter your name</h3><p>User Name:<input ng-model="userName"></input></p></div><div class="ngdialog-buttons"><button type="button" class="ngdialog-button ngdialog-button-primary" ng-click="closeThisDialog()">Cancel</button><button type="button" class="ngdialog-button ngdialog-button-primary" ng-click="confirm(userName)">Confirm</button></div>',    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內容:

<!doctype html><html><head> <title>A Server Template for ngDialog</title></head><body> <div>  <h3>Server Template for ngDialog</h3>  <li>Node.js</li>  <li>Express</li>  <li>AngularJS</li>  <li>MongoDB</li> </div></body></html>

引入ngDialog

要使用ngDialog,需要在HTML中使用script引入對應的js庫文件。另外還要在head部分引入幾個css文件。參考ngdialog.html即可。

ngDialog的庫文件可以到https://github.com/likeastore/ngDialog下載,或者到這里下載:http://cdnjs.com/libraries/ng-dialog。我是在后面這個鏈接下的0.4.0版本,把文件重命名了一下。重命名后的幾個文件如下:

  1. ngDialog-0.4.0.min.js
  2. ngDialog-0.4.0.min.css
  3. ngDialog-theme-default-0.4.0.min.css
  4. ngDialog-theme-plain-0.4.0.min.css

API摘要學習

我學習時遇到了一些疑惑,記錄在下面。

對話框內容模板

要顯示一個對話框,必須得指定待現實的內容。這是通過template屬性指定的。template有三種情況:

  1. 嵌入在js或html代碼里的純文字模板,此時需要同時在options里設置plain屬性為true,即“plain:true”,然后直接將一段html代碼賦值給template,比如template:<p>Text in ngDialog</p>
  2. 在HTML內定義template模板,同時給模板指定id,將id賦值給template選項,比如“template: ‘templateId'”。而模板可能是這樣的:<script type="text/ng-template" id="firstDialogId"><div><p>text in dialog</p></div></script>
  3. 以外部的html片段(文件)為模板,比如“template: ‘serverTpl.html'”,serverTpl.html文件在服務器上。

指定主題

可以在options里通過className指定主題,目前有ngdialog-theme-default和ngdialog-theme-plain兩個主題。這兩個注意對應兩個css文件,前面我們已經通過HTML引入了。

響應關閉等事件

對話框被關閉時,會發出一些事件,開發者可以監聽這些事件來獲得通知。具體事件有:

  1. ngDialog.opened
  2. ngDialog.closing
  3. ngDialog.closed

這些事件定義在$rootScope服務里,所以我們的controller構造函數必須依賴$rootScope。比如我們現在的模塊定義和controller定義:

angular.module(‘myApp', [‘ngDialog']). controller(‘myController', function(scope,scope,rootScope, ngDialog){

在模塊定義里注明依賴ngDialog模塊,在controller定義里注入了$rootScope和ngDialog。

如何監聽事件,看ngdialog.js代碼吧。

另外我們還可以在options中設置preCloseCallback,指定一個函數,這個函數在對話框取消關閉之前會調用到。https://github.com/likeastore/ngDialog這里有說明。注意,是取消對話框時會調用到,如果確認,不會調到哦。所以,這個preCloseCallback通常在阻止或提醒用戶放棄輸入時使用,比如用戶注冊,輸入了一些信息,想退,你可以問他是否要真的想放棄。

指定對話框的controller

可以通過options設置controller屬性來給一個對話框指定控制器。這個控制器可以是內聯(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)就可以創建這樣的對話框。ngDialog向$scope注入了兩個函數,一個是confirm(value),一個是closeThisDialog(reason),分別用來確認關閉對話框,取消關閉對話框。將它們關聯到確認和取消按鈕上,就可以確認、取消對話框。

假如我要讓用戶輸入用戶名,可以用ng-model指令將作用域內某個變量和input綁定,在調用confirm時傳入綁定的變量,這樣就可以在confirm中拿到用戶填寫的值來做進一步處理。我們的示例中的openConfirmDialog按鈕,點擊后就彈出一個讓用戶輸入名字的對話框,當用戶輸入完畢,點擊Confirm按鈕時,我們可以通過confirm方法的value參數獲得用戶名輸入框的值。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
3344国产精品免费看| 操91在线视频| 国产成人高清激情视频在线观看| 亚洲另类图片色| 亚洲精品短视频| 国产精品视频999| 欧美性猛交xxxx乱大交蜜桃| 国产剧情日韩欧美| 日韩av电影在线免费播放| 国产69精品久久久久久| 97香蕉久久夜色精品国产| 少妇高潮 亚洲精品| 欧美最近摘花xxxx摘花| 欧美电影免费观看高清完整| 久久免费精品日本久久中文字幕| 国产一区在线播放| 国产91色在线| 久久男人的天堂| 国产一区二区三区网站| 国产成人自拍视频在线观看| 国产视频一区在线| 98精品国产高清在线xxxx天堂| 国产精品成人av性教育| 精品视频一区在线视频| 国产一区二区在线免费| 国内外成人免费激情在线视频网站| 欧美另类99xxxxx| 欧美亚洲激情视频| 欧美一区二区三区精品电影| 欧美激情免费观看| 欧美三级免费观看| 精品国产一区久久久| 中文字幕亚洲一区在线观看| 亚洲视频在线观看网站| 日韩**中文字幕毛片| 欧美黑人国产人伦爽爽爽| 亚洲精品电影在线| 在线视频欧美性高潮| 国产a级全部精品| 91精品视频观看| 亚洲欧美另类自拍| 亚洲欧美成人网| 日本老师69xxx| 在线视频亚洲欧美| 久久人人爽国产| 久久亚洲精品小早川怜子66| 欧美大片免费观看| 欧美国产日韩精品| 国产精品h片在线播放| 欧美日韩在线免费观看| 美日韩在线视频| 国产一区二区三区在线播放免费观看| 国产成人精品在线观看| 中文字幕亚洲一区二区三区| 中文字幕av一区二区三区谷原希美| 亚洲第一精品久久忘忧草社区| 日韩欧美在线观看视频| 欧美最猛性xxxxx(亚洲精品)| 中文字幕亚洲综合久久筱田步美| 国产精品久久久久久久久久久久久久| 国产精品综合不卡av| 亚洲石原莉奈一区二区在线观看| 欧美激情性做爰免费视频| 成人午夜高潮视频| 日产精品99久久久久久| 亚洲国产精品推荐| 欧美乱大交做爰xxxⅹ性3| 国模视频一区二区| 好吊成人免视频| 国产91热爆ts人妖在线| 日韩成人网免费视频| 国产精品自拍视频| 国产精品入口尤物| 亚洲欧美综合区自拍另类| 亚洲午夜久久久影院| 91在线网站视频| 91精品国产91久久| 欧美一级电影久久| 亚洲色图激情小说| 欧美国产一区二区三区| 亚洲天堂一区二区三区| 久久久久久久久久久久av| 91中文字幕一区| 久久99热这里只有精品国产| 国产在线视频91| 欧美性xxxx极品hd欧美风情| 77777亚洲午夜久久多人| 国产一区二区在线免费| 亚洲欧美成人在线| 国产精品永久免费视频| 色先锋资源久久综合5566| 成人福利网站在线观看| 欧美最顶级丰满的aⅴ艳星| 亚洲第一页中文字幕| 久久久久亚洲精品成人网小说| 欧美精品电影在线| 国产原创欧美精品| 日韩av在线网站| 国产精品wwww| 日韩欧美主播在线| 一区二区三区无码高清视频| 亚洲日本aⅴ片在线观看香蕉| 日韩免费视频在线观看| 国产精品视频在线观看| 在线视频亚洲欧美| 中文字幕亚洲综合久久| 国产一区二区精品丝袜| 亚洲精品久久久久中文字幕欢迎你| 69**夜色精品国产69乱| 国产成人avxxxxx在线看| 清纯唯美日韩制服另类| 国产精品99久久99久久久二8| 久久国产视频网站| 97超碰国产精品女人人人爽| 成人激情视频在线播放| 国产丝袜精品视频| 一夜七次郎国产精品亚洲| 亚洲综合日韩中文字幕v在线| 91av视频在线| 国产成人精品网站| 欧美综合一区第一页| 亚洲国产91精品在线观看| 最近2019中文免费高清视频观看www99| 亚洲女人被黑人巨大进入| 国产精品久久综合av爱欲tv| 久久夜色撩人精品| 日韩一级裸体免费视频| 97视频网站入口| 国产精品网站大全| 日本人成精品视频在线| 亚洲成人久久一区| 日韩麻豆第一页| 亚洲精品美女在线观看| 欧美性一区二区三区| 欧美极品美女视频网站在线观看免费| 国产成人精品久久久| 欧美激情手机在线视频| 亚洲在线第一页| 在线视频免费一区二区| 中文字幕国产精品| 欧洲亚洲妇女av| 亚洲国模精品一区| 最近2019中文字幕第三页视频| 亚洲国产成人精品女人久久久| 伊人久久大香线蕉av一区二区| 久久久中精品2020中文| 国模叶桐国产精品一区| 久久99久久久久久久噜噜| 久久久久久久999精品视频| 91精品综合久久久久久五月天| 欧洲成人在线观看| 国产精品久久不能| 亚洲97在线观看| 91精品成人久久| 日韩在线免费视频观看| 在线日韩精品视频| 欧美日韩999| 一区二区欧美激情| 91精品久久久久久久久中文字幕| 91视频免费在线| 亚洲va男人天堂| 欧美理论电影网| 亚洲欧美一区二区激情| 庆余年2免费日韩剧观看大牛|