欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2018年05月11日 09:06:45   作者:foruok  
本篇文章主要介紹了Node.js使用對話框ngDialog的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

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

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

{template: 'tplId',closeByEscape: false}

示例搭建

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

添加自己寫的文件

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

ngdialog.html內(nèi)容:

<!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內(nèi)容:

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內(nèi)容:

<!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引入對應(yīng)的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摘要學(xué)習(xí)

我學(xué)習(xí)時遇到了一些疑惑,記錄在下面。

對話框內(nèi)容模板

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

  1. 嵌入在js或html代碼里的純文字模板,此時需要同時在options里設(shè)置plain屬性為true,即“plain:true”,然后直接將一段html代碼賦值給template,比如template:<p>Text in ngDialog</p>
  2. 在HTML內(nèi)定義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文件在服務(wù)器上。

指定主題

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

響應(yīng)關(guān)閉等事件

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

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

這些事件定義在$rootScope服務(wù)里,所以我們的controller構(gòu)造函數(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中設(shè)置preCloseCallback,指定一個函數(shù),這個函數(shù)在對話框取消關(guān)閉之前會調(diào)用到。https://github.com/likeastore/ngDialog這里有說明。注意,是取消對話框時會調(diào)用到,如果確認(rèn),不會調(diào)到哦。所以,這個preCloseCallback通常在阻止或提醒用戶放棄輸入時使用,比如用戶注冊,輸入了一些信息,想退,你可以問他是否要真的想放棄。

指定對話框的controller

可以通過options設(shè)置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,就可以在調(diào)用ngDialog.open(options)時在options里設(shè)置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。

確認(rèn)對話框

比如讓用戶確認(rèn)刪除,讓用戶輸入。使用openConfirm(options)就可以創(chuàng)建這樣的對話框。ngDialog向$scope注入了兩個函數(shù),一個是confirm(value),一個是closeThisDialog(reason),分別用來確認(rèn)關(guān)閉對話框,取消關(guān)閉對話框。將它們關(guān)聯(lián)到確認(rèn)和取消按鈕上,就可以確認(rèn)、取消對話框。

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • NPM配置私服構(gòu)建內(nèi)網(wǎng)中央倉庫過程詳解

    NPM配置私服構(gòu)建內(nèi)網(wǎng)中央倉庫過程詳解

    這篇文章主要為大家介紹了NPM配置私服構(gòu)建內(nèi)網(wǎng)中央倉庫過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • node.js實現(xiàn)帶進度條的多文件上傳

    node.js實現(xiàn)帶進度條的多文件上傳

    這篇文章主要為大家詳細(xì)介紹了node.js實現(xiàn)攜帶進度條的多文件上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • Node.js + express基本用法教程

    Node.js + express基本用法教程

    這篇文章主要介紹了Node.js + express基本用法,結(jié)合實例形式分析了nodejs導(dǎo)入express、路由訪問、數(shù)據(jù)處理等相關(guān)操作技巧,需要的朋友可以參考下
    2019-03-03
  • Node.js Event Loop各階段講解

    Node.js Event Loop各階段講解

    今天小編就為大家分享一篇關(guān)于Node.js Event Loop各階段講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • node.js實現(xiàn)pdf與圖片互轉(zhuǎn)代碼示例

    node.js實現(xiàn)pdf與圖片互轉(zhuǎn)代碼示例

    因工作需求,記錄一次如何在Node中pdf與圖片互轉(zhuǎn)各種操作,這篇文章主要給大家介紹了關(guān)于node.js實現(xiàn)pdf與圖片互轉(zhuǎn)的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-04-04
  • 一文教會你從Windows中完全刪除node.js

    一文教會你從Windows中完全刪除node.js

    作為新手nodejs卸載后安裝就總出錯,下面這篇文章主要給大家介紹了關(guān)于如何從Windows中完全刪除node.js的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • 使用 Node.js 實現(xiàn)圖片的動態(tài)裁切及算法實例代碼詳解

    使用 Node.js 實現(xiàn)圖片的動態(tài)裁切及算法實例代碼詳解

    這篇文章主要介紹了使用 Node.js 實現(xiàn)圖片的動態(tài)裁切功能,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • socket.io學(xué)習(xí)教程之基礎(chǔ)介紹(一)

    socket.io學(xué)習(xí)教程之基礎(chǔ)介紹(一)

    socket.io提供了基于事件的實時雙向通訊,所以下面這篇文章主要介紹了關(guān)于socket.io的相關(guān)資料,主要介紹了學(xué)習(xí)socket.io的基礎(chǔ)知識,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-04-04
  • websocket實現(xiàn)Vue?3和Node.js之間的實時消息推送

    websocket實現(xiàn)Vue?3和Node.js之間的實時消息推送

    使用?WebSocket?實現(xiàn)實時消息推送是一種高效的方式,可以在客戶端和服務(wù)器之間建立長連接,實現(xiàn)低延遲的雙向通信,以下是一個簡單的示例,展示如何在前端使用?Vue?3?和后端使用?Node.js?搭建一個?WebSocket?實現(xiàn)實時消息推送的應(yīng)用
    2024-06-06
  • 一文詳解NPM如何換源

    一文詳解NPM如何換源

    在每一次的實際開發(fā)過程中我們都會下載相關(guān)的依賴包,最官方的是 npm,但是該服務(wù)器對于國內(nèi)開發(fā)者來說,下載起來是比較慢的,所以我們需要換源,下面這篇文章主要給大家介紹了關(guān)于NPM如何換源的相關(guān)資料,需要的朋友可以參考下
    2023-02-02

最新評論