摘要:为了适应表单校验的灵活性,我们使用这种模式会事半功倍,提供校验信息的组件仅仅声明渲染表单错误提示信息需要设计的状态变量即可,比如等等,对于错误信息的文案及样式,统统交由错误提示组件的使用者完成。
06 Use
Render Props最近在React社区中引起了轰动,但是与之类似的模式在Angular中似乎并没有得到太多关注。我在之前写的文章提及过,TemplateRefs就是Angular中的Render Props,同时我会在这篇文章中列举一个简单易用的例子。
Note: TemplateRef是一个类名而是一个html标签,它们本质上是相同的。不过你可能会在项目中更频繁地使用 ,但是在网上你可以很容易的搜索到关于TemplateRef的知识,因为 会给你提供很多html5中的标签的信息。
我们已有的实现中,使用自定义内容指令(content directives)。当组件作者提前了解使用该toggle组件的父组件所需要的状态时,那么它将会正常的运作。但是如果父组件所需要的状态并不在我们的设想之内,我们该怎么办?
目标将toggle组件的状态直接提供给父组件,同时允许父组件提供相应的渲染视图(view)。
实现这里
从toggle组件中传入的状态是通过let关键字在父组件的
let关键字的使用方式类是这样的:let-templatevar="inputvar",templatevar指代在
这种语法会有效地避免命名冲突,比如在父组件作用域中已经有一个inputvar变量了。
成果stackblitz演示地址
译者注这种组件设计模式按我个人的理解,其实是依赖倒置原则在视图渲染层的一种延伸,为什么这么说呢?是因为通常情况下子组件视图的渲染逻辑取决于传入的props状态和自身提供的模板,这在大多数情况下不会造成任何困扰,但是当我们无法在提前得知我们需要渲染什么的时候,这个问题就会变得十分棘手。
一种解决方法,我们可以使用条件渲染指令,根据传入的状态来判定组件渲染的状态,这种解决方法在情况比较少的情况下是可以解决问题的,但是当情况数量十分庞大的情况下,增加过多的条件判定会致使子组件的模板代码量剧增,同时降低性能,因为每次渲染都会进行若干次条件逻辑判断。
除了上面的解决方法,就是使用正文中所提及的模式了,这种模式将子组件视图的渲染逻辑倒置为子组件仅仅声明模板中所会使用的状态变量,对于这些变量和模板的注入工作,全权赋予父组件,因此会使子组件的复用性和可测试性大大提高。
正文中仅列举了一个简单的例子中,我这里在简单提及一个实际工作可能会用到的例子,就是表单校验的错误提示组件,一般前端组件设计但凡涉及表单,都会是十分复杂的,更不用说校验这种灵活性很高的功能了。
为了适应表单校验的灵活性,我们使用这种模式会事半功倍,提供校验信息的组件仅仅声明渲染表单错误提示信息需要设计的状态变量即可,比如dirty、touched等等,对于错误信息的文案及样式,统统交由错误提示组件的使用者完成。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/107828.html
摘要:原文如那样,我们将使用一个相对简单的组件来说明这些模式。组件的职责是仅仅是管理一个简单的布尔值状态属性。文件夹并且特别是,将针对库在不同的情形下的使用做出相应的改变。 写在前头 Angular到现在已经到5.x的版本了,对于MVVM框架我首先接触的是angularjs后来又转为react,之后换了工作因项目技术栈的原因又转换到之前的angularjs,在实际工作中实施了公司几个比较重要...
摘要:目标提供一些方法或指令给组件使用者,使其可以与所提供的元素交互并修改它们。这个指令拥有一个属性并与组件共享,该属性将决定属性的值是还是。 07 使用 Content Directives 原文: Use Content Directives 因为父组件会提供所有相关的 UI 元素(比如这里的 button),所以 toggle 组件的开发者可能无法满足组件使用者的一些附加需求,比如,...
摘要:同时,依赖注入机制是依附于组件本身存在的,并不依附于模板的层级关系,因此不会面临问题二的困扰。对于木偶组件本身,往往作为消费者存在,这种情况下使用机制可能会达到更好的效果。 03-a Communicate Between Components Using Dependency Injection 原文: Communicate Between Components Using Dep...
摘要:相关话题装饰器将会返回在组件标签包含的内容中,第一个符合选择器的子组件或者子指令的引用,比如。或者装饰器是用来获取在组件内部模板中使用的单个或者多个组件的。 02 Write Compound Components 原文: Write Compound Components 目标 我们需要实现的需求是能够使使用者通过组件动态的改变包含在它内部的内容。 实现 我们可以把toggle抽象...
摘要:实现模板引用变量是获取某个元素组件或者指令引用的一种方式,这个引用可以在当前的视图模板中的任何地方使用。它们通常是以或者的语法声明的。成果在中,我通过打印模板引用变量所指向的类的名字来演示它所代表的引用。 05 Handle Template Reference Variables with Directives 原文: Handle Template Reference Variab...
阅读 3011·2021-10-08 10:18
阅读 731·2019-08-30 15:54
阅读 1064·2019-08-29 18:43
阅读 2436·2019-08-29 15:33
阅读 1300·2019-08-29 15:29
阅读 1600·2019-08-29 13:29
阅读 1022·2019-08-26 13:46
阅读 1695·2019-08-26 11:55