zoukankan      html  css  js  c++  java
  • Angular2

    在Angular项目的设计中,我们往往需要定义一些全局的数据,如:应用名称,版本,当前环境,后端服务器地址,当前用户信息等,并希望能一次定义,多处共享,这里我们介绍如何用service来为整个应用提供全局配置服务。

    (1) 应用环境

    1. 定义名为App_Configuration的interface,该配置中,我们定义了应用的基本信息字段,开发环境和生产环境的参数类型

    //App_Configuration..config.ts
    export interface App_Configuration{
      app:{
        base:{
          name:string,
          version:string
        },
        environments:{
          dev:{
            API:{
              service:{
                report:string
              },
              backend:{
                schema:string,
                core:string
              }
            }
          },
          prod:{
            API:{
              service:{
                report:string
              },
              backend:{
                schema:string,
                core:string
              }
            }
          }
        }
      }
    }
    

      

    2. 配置一个 App_Config 常量

    import { App_Configuration } from './app.config.interface';
    console.log('import App_Configuration..');
    export const App_Config: App_Configuration = {
        app:{
          base:{
            name:'Ng_App_Demo',
            version:'0.1'
          },
          environments:{
            dev:{
              API:{
                service:{
                  report:'http://xx.xx.xx.xx:yyyy'
                },
                backend:{
                  schema:'http://xx.xx.xx.xx:yyyy',
                  core:'http://zz.zz.zz.zz:yyyy'
                }
              }
            },
            prod:{
              API:{
                service:{
                  report:'http://aa.aa.aa.aa:yyyy'
                },
                backend:{
                  schema:'http://bb.bb.bb.bb:yyyy',
                  core:'http://cc.cc.cc.cc:yyyy'
                }
              }
            }
          }
        }
      };
    

      

    3. 定义一个 environment.helper.ts

    import { App_Config } from '../configurations/app.config'
    export const EnvHelper = {
      getEnvConfig:function(siteUrl){
        let envType = EnvHelper.getEnvType(siteUrl);
        let config;
    //根据当前用户访问地址,匹配到对应环境的配置信息
        switch(envType){
          case 'dev':
            config = App_Config.app.environments.dev;
            break;
          case 'prod':
            config = App_Config.app.environments.prod;
            break;
          default:
            config = App_Config.app.environments.dev;
            break;
        }
        return config;
      },
    
      getHostName:function(url){
        let parser = document.createElement('a');
        parser.href = url;
        return parser.host;
      },
    
      getEnvType:function(url){
        if(EnvHelper.isDevelopment(url)){
          return 'dev';
        }
        if(EnvHelper.isProduction(url)){
          return 'prod';
        }
      },
    //当前是否为测试环境
      isDevelopment:function(siteUrl){
        let devHosts = App_Config.app.environments.dev.others.ENV.hosts;
        if(devHosts.indexOf(EnvHelper.getHostName(siteUrl)) !== -1){
          return true;
        }
        return false;
      },
    
    //当前是否为生产环境
      isProduction:function(siteUrl){
        let prodHosts = App_Config.app.environments.prod.others.ENV.hosts;
        if(prodHosts.indexOf(EnvHelper.getHostName(siteUrl)) !== -1){
          return true;
        }
        return false;
      }
    };
    

      

    4. 提供一个 environment service

    import { Injectable } from '@angular/core';
    import { EnvHelper  } from '../helpers/environment.helper';
    export type SiteStateType = {
      [key: string]: any
    };
    
    @Injectable()
    export class EnvSvc{
      _envState:SiteStateType = {
        url:window.location.href,
    //调用EnvHelper得到当前应用环境配置
        config:EnvHelper.getEnvConfig(window.location.href)
      };
    
      constructor() {
    
      }
    
      get envState(){
    //在开放的获取应用环境状态时,克隆一份_envState,避免外部程序修改配置
        return this._envState = this._clone(this._envState);
      }
    
      set envState(value) {
        throw new Error('do not mutate the `.envState` directly');
      }
    
      get(prop?: any){
        const state = this.envState;
        return state.hasOwnProperty(prop) ? state[prop] : state;
      }
    
      private _clone(object: SiteStateType){
        return JSON.parse(JSON.stringify(object));
      }
    }
    

      

    5. 在app.module.ts 中providers 添加EnvSvc并在相应component中注入即可。

  • 相关阅读:
    演练:向 MVC 项目添加 ASP.NET AJAX 脚本
    如何:在 MVC 中从客户端实现远程验证
    熟悉 ASP.NET MVC 类
    在 ASP.NET MVC 应用程序中传递数据
    了解 MVC 应用程序执行过程
    通过调用多个操作创建 ASP.NET MVC 视图
    演练:使用区域组织 ASP.NET MVC 应用程序
    错误:GridView {GridViewID} fired event RowEditing which wasn't handled
    如何检测数据库中对象被锁定及解除锁定的方法
    关于ASP.NET中OnClientClick事件Eval函数解析错误的处理
  • 原文地址:https://www.cnblogs.com/wzcblogs/p/6294037.html
Copyright © 2011-2022 走看看