Angular中的装饰器

Angualr中的装饰器是一个函数,它将元数据添加到类、类成员(属性、方法)和函数参数

用法:要想用装饰器,把它放到被装饰对象的上面或做左面

1.类装饰器:

 类装饰器应用于类构造函数,可以用来监控、修改或替换类定义

类装饰器表达式会在运行时当作函数被调用,类的构造函数作为唯一的参数

@Component 标记类作为组件并收集组件配置元数据(继承Directive)

@Directive 标记类作为指令并收集组件配置元数据

声明当前类时一个指令,并提供关于该指令的元数据

@Pipc 声明当前类是一个管道,并且提供关于管道的元数据

@Injectable 标记元数据并可以使用Injector注入器注入

@NgModule是一个装饰器函数,它接收一个用来描述模块属性的元数据对象

重要的属性有:

declarations 声明本模块中拥有的视图类(Angular中有三种视图类:组件、指令和管道)

exports - declarations的子集,可用于其他模块的组件模板

imports 本模块声明的组件模板需要的类需要的类所在的其他模块 模块的导入声明

providers -服务的创建者,并加入到全局服务列表中,

bootstrap --指定应用的主视图(称为根节点),它是所有其他视图的宿主

2.属性装饰器:

属性装饰器表达式会在运行时当作函数被调用

传入2个参数

(1).对于静态成员来说是类的构造器,对于实例成员是类的原型对象

(2).成员名字

@Input 声明一个输入属性,以便我们可以通过属性绑定更新它

@Output 声明一个输出属性,以便我们可以通过事件绑定进行订阅

@Hostbinding 把宿主元素的属性(比如CSS类) 绑定到指令/组件的属性

@HostListener 通过指令/组件的方法订阅宿主元素的事件

@ContentChild 配置一个内容查询

@ViewChild 配置一个视图查询

@ContentChildren 配置多个内容查询(返回QueryList类型)

@ViewChildren 配置多个视图查询(返回QueryList类型)

3.参数装饰器:

参数装饰器表达式会在运行时当作函数被调用

传入3个参数

(1).对于静态成员来说是类的构造函数,对于实例成员是类的原型对像

(2).成员名字

(3).参数在函数列表中的索引

@Ingject指定依赖关系的参数装饰器(一般用来注入被标记Injectable的类)

@Optional将依赖项标记为可选的参数类型,如果没有找到依赖关系,注射器将提供null

@Self指定注射器只能从本身检索依赖关系

@SkipSelf指定注射器只能从父类检索依赖关系

@Host按照依赖关系来检索

原文地址:https://www.cnblogs.com/violinh/p/12148318.html

时间: 2024-10-08 19:54:09

Angular中的装饰器的相关文章

@修饰符--python中的装饰器

http://blog.csdn.net/shangzhihaohao/article/details/6928808 装饰器模式可以在不影响其他对象的情况下,以动态.透明的方式给单个对象添加职责,也能够处理那些可以撤销的职责.经常用于日志记录.性能测试等场合. 想象一下这个很常见的场景,你写了一个方法只提供给以登陆的用户访问(事实上我也是通过django的@login_required才了解到@修饰符的),你可以写以下代码: 这当然没什么问题,但是你又写了一个方法B,也要求只有登录用户可以访问

Python 中实现装饰器时使用 @functools.wraps 的理由

Python 中使用装饰器对在运行期对函数进行一些外部功能的扩展.但是在使用过程中,由于装饰器的加入导致解释器认为函数本身发生了改变,在某些情况下--比如测试时--会导致一些问题.Python 通过 functool.wraps 为我们解决了这个问题:在编写装饰器时,在实现前加入 @functools.wraps(func) 可以保证装饰器不会对被装饰函数造成影响.比如,在 Flask 中,我们要自己重写 login_required 装饰器,但不想影响被装饰器装饰的方法,则 login_req

自己编写一个装饰器中的装饰器函数

看了"大道曙光"的<探究functools模块wraps装饰器的用途>的文章.基本上弄清了wraps的工作原理,为了检验一下自己理解的程度,于是动手写一个类似的 wraps函数,请大家指教. #!/usr/bin/env python # -*- coding: utf-8 -*- #filename : mywrapper.py #date: 2017-06-02 ''' wrapper function by my code.''' import functools i

Typescript中的装饰器原理

Typescript中的装饰器原理 1.小原理 因为react中的高阶组件本质上是个高阶函数的调用, 所以高阶组件的使用,我们既可以使用函数式方法调用,也可以使用装饰器. 也就是说,装饰器的本质就是一个高阶函数, 就是利用TypeScript的弱类型特性和装饰器特性,实现了一个加强版. 2.以一个例子来讲 //定义一个装饰器函数decTest function decTest(constructor: Function) { console.log(constructor("hello!&quo

【react】---react中使用装饰器(高阶组件的升级用法)

一.creact-react-app中使用装饰器 运行 npm run eject 可以让由create-react-app创建的项目的配置项暴露出来 此时,项目中多了一个config文件,并且各个配置文件已经暴露出来了.(运行npm run eject之前,保证本地没有待提交到git的文件) 安装babel插件npm install --save-dev @babel/plugin-proposal-decorators 修改package.json文件的babel配置项 "babel&quo

二十五:视图之类视图中使用装饰器

对于url的保护,一般是通过装饰器实现,如:某个页面需要登录后才能访问 函数视图实现 from flask import Flask, render_template, requestfrom functools import wrapsapp = Flask(__name__)def login_required(func): @wraps(func) def wrapper(*args, **kwargs): username = request.args.get('username') r

如何理解python中的装饰器, 这篇文章就够了!

1. python中的函数 理解裝飾器之前先要理解閉包, python中閉包的出現是因爲函數在python中也是一個對象, 也可以被引用, 然後調用, 比如 def log(): print('我是一些log信息') if __name__ == '__main__': print(type(log)) log_func = log log_func() 執行結果如下 <class 'function'> 我是一些log信息 可以看到log函數是一個對象, 可以被賦值給log_func, lo

Python 中的装饰器

说到装饰器是我们每个学Python人中的心痛. 装饰器作用:是用来装饰其他函数的,为其他函数添加新功能. 原则:1.不能改变被修饰函数的源代码. 2.不能修改被修饰函数的调用方式. 学装饰器前还需要了解的东西: 返回值(return): return 语句是可选的,它可以定义在函数体的任意位置表示函数调用到此结束.如果没有return语句输出的是none,如果有return语句但是return后没有跟东西,也是返回的是none. 注意:(1)要想看到return后边的值,需要打印出来print(

理解Python中的装饰器

文章先由stackoverflow上面的一个问题引起吧,如果使用如下的代码: @makebold @makeitalic def say(): return "Hello" 打印出如下的输出: <b><i>Hello<i></b> 你会怎么做?最后给出的答案是: def makebold(fn): def wrapped(): return "<b>" + fn() + "</b>&q