angular 使用dialog的经验

利用angular在近期的工作中使用了dialog的方式,总结下经验

由于dialog显示的内容不同,需要用到angular 的ng-include加载不同的文件
1 dialog利用指令的方式

app.directive(‘dialog‘, function() {
  return {
    restrict: ‘AE‘,
    scope: {
      loadData: ‘=‘
    },
    template: ‘<div ng-show="loadData.isShow" class="dialog-main">‘ +
          ‘<div class="dialog-box">‘ +
            ‘<div class="dialog-content"><i class="close-button" ng-click="closeDialog()"><img src="image/close.png" /></i>‘ +
            ‘<div ng-include="loadData.template.url"></div>‘ +   // 注意下利用ng-inclue加载不同的页面文件
          ‘</div>’ +
        ’</div>‘ ,

    replace: true,
    link: function (scope, element, attr) {
      scope.closeDialog = function(){
        scope.loadData.isShow = false;
      }
    }
  }
});

2 使用dialog指令的方式

因为需要的dialog页面不少,所以考虑dialog组件直接放到$rootScope环境中,

<div ng-app="zswq">
  <dialog load-data="dialog_data"></dialog>
  <div app-header-area></div>
  <div class="content flex" >
</div>

3 弹出dialog的方式

  可点击按钮弹出,利用ng-click="dialog_data.isShow=!data.isShow; dialog_data.data={id:0,unitName:‘‘};dialog_data.template.url=‘/view/template/content/manage/employee/add_employee.html‘ ”
  好的方式是写在逻辑中,ng-click="getDialog()"  ,然后在getDialog函数中 用 dialog_data.isShow=!data.isShow; dialog_data.data={id:0,unitName:‘‘};dialog_data.template.url=‘/view/template/content/manage/employee/add_employee.html‘

4  注意刷新的问题
  例如公司编辑页面,公司不同,就需要传递的值就不同,放到 dialog_data.data对象中(看第3条),通过利用 dialog_data.data取传递。
  但是注意刷新的问题,编辑不同的公司信息,需要弹出的是一个dialog,但是因为dialog中加载的是没有改变的静态页面,不存在重新加载,页面的数据显示的是原来的(虽然已经更改了dialog_data.data对象),所以就要考虑在弹出dialog的事件中触发下更新的函数

  因为dialog处于$rootScope环境,所以$rootScope中$watch监听dialog_data.data对象的改变,如果改变,就向下广播$broadcast一个函数dialogWinNeedReload,位于dialog的那个页面接收广播,更改绑定数据,重新请求

    $scope.$on("dialogWinReload",function(){
      $scope.queryCompanyData = {
        "cId":$rootScope.dialog_data.data.cid,
        "token":$cookies.get("token")
        }
      $scope.initCompany();
    });

    

    $rootScope.$watch("dialog_data.data",function(){
      $rootScope.$broadcast("dialogWinReload")
    })

时间: 2024-10-13 05:46:50

angular 使用dialog的经验的相关文章

[转]Angular 4|5 Material Dialog with Example

本文转自:https://www.techiediaries.com/angular-material-dialogs/ In this tutorial, we're going to learn how to use the Angular Material Dialog component to build a custom dialog example. We'll also see common cases to work with the Angular Material Dialo

[Angular 8 Unit Testing] Testing a component

Setting up a Presentational Component: import {Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation} from '@angular/core'; import {Course} from '../model/course'; import { MatDialog, MatDialogConfig } from '@angular/material/dialog'; imp

AngularJS Eclipse——新手入门【翻译+整理】

原文地址 本文介绍如何安装和配置 AngularJS Eclipse.Eclipse 插件是基于强大的 JavaScript 推断引擎(javascript inference engine)Tern.js, 它是由JavaScript编写的.若在 java 环境下使用该引擎,需要使用 tern.java.它用 node.js 执行 tern.js.这就是为什么你在下面将看到的必须安装 node.js 或是 Eclipse 内置的 node.js. 如果不安装 node.js 或使用 Eclip

AngulaJS实战总结, 带你进入AngularJS世界(待续)

AngulaJS实战总结, 带你进入AngularJS世界(待续) 使用AngularJS  进行Hybrid App 开发已经有一年多时间了,这里做一个总结. 一.AngularJS 初始化加载流程 1.浏览器载入HTML,然后把它解析成DOM.2.浏览器载入angular.js脚本.3.AngularJS等到DOMContentLoaded事件触发.4.AngularJS寻找ng-app指令,这个指令指示了应用的边界.5.使用ng-app中指定的模块来配置注入器($injector).6.注

Android 在非主线程无法操作UI意识

Android在应用显示Dialog是一个非常easy事儿,但我从来没有尝试过Service里面展示Dialog. 经验UI操作要在主线程,本地的服务Service是主线程里没错,可是远程service里面显示Dialog,听起来是不是就应该没有在主线程里面了呢? 尝试一下就知道了,写了个AIDL的调用,client端去调用AIDL.在Service这边就是去显示一个Dialog. AIDL的部分就忽略了.Service这边的代码就和Activity上显示dialog一样. AlertDialo

angularJs 问题

1. IE不能渲染指令中的 style="background-color",而chrome和firefox可以 <!DOCTYPE html> <html ng-app="Dialog"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>direct

AngularJS 全局scope与Isolate scope通信

在项目开发时,全局scope 和 directive本地scope使用范围不够清晰,全局scope与directive本地scope通信掌握的不够透视,这里对全局scope 和 directive本地scope的使用做一个总结. 一.scope作用域 1.AngularJS中,子作用域一般都会通过JavaScript原型继承机制继承其父作用域的属性和方法.但有一个例外:在directive中使用scope: { ... },这种方式创建的作用域是一个独立的"Isolate"作用域,它也

AngulaJS实战总结

一.AngularJS 初始化加载流程 1.浏览器载入HTML,然后把它解析成DOM. 2.浏览器载入angular.js脚本. 3.AngularJS等到DOMContentLoaded事件触发. 4.AngularJS寻找ng-app指令,这个指令指示了应用的边界. 5.使用ng-app中指定的模块来配置注入器($injector). 6.注入器($injector)是用来创建“编译服务($compile service)”和“根作用域($rootScope)”的. 7.编译服务($comp

使用AngularJS 进行Hybrid App 开发已经有一年多时间了,这里做一个总结

一.AngularJS 初始化加载流程 1.浏览器载入HTML,然后把它解析成DOM.2.浏览器载入angular.js脚本.3.AngularJS等到DOMContentLoaded事件触发.4.AngularJS寻找ng-app指令,这个指令指示了应用的边界.5.使用ng-app中指定的模块来配置注入器($injector).6.注入器($injector)是用来创建“编译服务($compile service)”和“根作用域($rootScope)”的.7.编译服务($compile se