react 工厂方法——createfactory使用详解
最近在学习react过程中,接触到其中的createfactory方法,发现其ag捕鱼王app官网上的说明很简单。单看ag捕鱼王app官网的解释要想使用createfactory还真是有些困难,而且网上对这个方法的使用说的都不是很详细。在下不才,试着将使用createfactory的方法分享给大家,希望对大家有所帮助。
下面我们先看ag捕鱼王app官网解释
react.createfactory
factoryfunction createfactory(
string/reactclass type
)
上面函数返回一个用于生成给定类型的reactelement的函数,类似于 react.createelement。对于type参数可以是html标签名字(例如:“div”,“li”等),也可以是reactclass对象。
以上就是ag捕鱼王app官网上面的createfactory的说明,但是对于这个方法的使用,ag捕鱼王app官网上面并没有具体的例子。对于这个方法的概念的说明,我觉得还是ag捕鱼王app官网上的比较权威。我在这里只对createfactory的使用进行说明。
type参数为html标签名字
首先我们来看ag捕鱼王app官网上的一个例子
例一
var child1 = react.createelement('li', null, 'first text content');
var child2 = react.createelement('li', null, 'second text content');
var root = react.createelement('ul', { classname: 'my-list' }, child1, child2);
reactdom.render(root, document.getelementbyid(content));
这个例子通过createelement方法创建了两个li标签,然后通过createelement方法创建了ul标签,并将li标签添加为ul的子节点。关于createelement的使用各位可以参考
下面我们通过createfactory来修改这个例子
例二
var factory = react.createfactory("li");
var child1 = factory(null,'first text content');
var child2 = factory(null,'second text content');
var root = react.createelement('ul',{classname:'my-list'},child1,child2);
reactdom.render(
root,
document.getelementbyid('content')
);
当然,ul也可以通过创建一个工程方法来生成ul标签,但是在我们这个例子中只有一次ul的创建,所以我们可以通过createelement来创建ul元素。当然我们可以再生成一个ul的工厂方法用于生成ul元素,代码如下
例三
var factory = react.createfactory("li");
var child1 = factory(null,'first text content');
var child2 = factory(null,'second text content');
var ulfactory = react.createfactory('ul');
var root = ulfactory({classname:'my-list'},child1,child2);
reactdom.render(
root,
document.getelementbyid('content')
);
除此之外,react还为html标签提供了内置的工厂方法 react.dom.htmltag。同样我们使用内置的工厂方法修改上面的例子
例四
var factory = react.createfactory("li");
var child1 = factory(null,'first text content');
var child2 = factory(null,'second text content');
var root = react.dom.ul({classname:'my-list'},child1,child2);
reactdom.render(
root,
document.getelementbyid('content')
);
同样的对于li元素我们也可以使用内置的工厂方法,代码如下
例五
var root = react.dom.ul(
{classname:'my-list'},
react.dom.li(null,'first text content2'),
react.dom.li(null,'second text content2')
);
reactdom.render(
root,
document.getelementbyid('content')
);
这样的代码看起来是不是更简单。
以上所有就是指定参数类型为html标签名字的工厂方法的使用。下面我们看使用指定参数类型为reactclass的使用方法。
type参数为reactclass
同样我们通过指定参数为reactclass对例一进行改写。代码如下
例六
var cli = react.createclass({
render: function(){
return (
{this.props.text}
);
}
});
var factory = react.createfactory(cli);
var child1 = factory({text:'first text content'});
var child2 = factory({text:'second text content'});
var root = react.dom.ul({classname:'my-list'},child1,child2);
reactdom.render(
root,
document.getelementbyid('content')
);
在上面的例子中,通过使用reactclass的方式创建li的工厂方法,在生成li元素的时候不能再使用下面的情况
var child1 = factory(null,'first text content');
var child2 = factory(null,'second text content');
因为如果使用这样的方式,虽然可以创建成功li元素,但是li中的文本并没有被生成。所以我们需要借助props来生成其文本。
同样对于ul元素,我们也可以使用reactclass的方式先生成工厂方法,然后再使用工厂方法创建ul元素。使用方法是相同的,在这里我就不再举例子了。大家可以自己试一试。
通过上面的所有的例子,单就createfactory来说其组合方式就有很多。所以说react的使用方式非常的灵活,我们可以选择适应自己的方式来写我们的代码。
转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处
本文地址:
相关文章
发布时间:2023/08/24 浏览次数:99 分类:c
-
工厂方法是 c 中的一种对象创建设计模式,用于创建对象同时隐藏其组合,以便用户可以使用接口而无需看到任何方法调用。c 中的工厂方法 工厂是虚拟构造函数,允许程序员设计让用户与
发布时间:2023/08/09 浏览次数:346 分类:java
-
在本文中,我们将讨论此方法并查看一个带有解释的示例。在 javafx 中使用 setcellvaluefactory 方法 在下面的示例中,我们创建了一个包含一些数据的简单表。 我们示例的代码如下所示。
解决 java 错误 java.lang.noclassdeffounderror: org/apache/commons/logging/log
发布时间:2023/07/11 浏览次数:168 分类:java
-
本篇文章介绍了 java 中的 java.lang.noclassdeffounderror: org/apache/commons/logging/logfactory 错误。解决java.lang.noclassdeffounderror: org/apache/commons/logging/logfactory
node.js 与 react js 的比较
发布时间:2023/03/27 浏览次数:173 分类:node.js
-
本文比较和对比了两种编程语言,node.js 和 react。react 和 node.js 都是开源 javascript 库的示例。 这些库用于构建用户界面和服务器端应用程序。
在 typescript 中 react usestate 钩子类型
发布时间:2023/03/19 浏览次数:246 分类:typescript
-
本教程演示了如何在 typescript 中使用 react usestate hook。
typescript 中的 react 事件类型
发布时间:2023/03/19 浏览次数:477 分类:typescript
-
本教程演示了如何在 typescript 中为 react 事件添加类型支持。
在 react 中循环遍历对象数组
发布时间:2023/03/18 浏览次数:602 分类:react
-
在 react 中循环对象数组: 使用 map() 方法迭代数组。 我们传递给 map() 的函数会为数组中的每个元素调用。 该方法返回一个新数组,其中包含传入函数的结果。 export default function app (
获取 react 中元素的类名
发布时间:2023/03/18 浏览次数:340 分类:react
-
在 react 中使用 event.target 获取元素的类名 获取元素的类名: 将元素上的 onclick 属性设置为事件处理函数。 访问元素的类名作为 event.currenttarget.classname 。 export default function app () { cons
如何将 key 属性添加到 react 片段
发布时间:2023/03/18 浏览次数:206 分类:react
-
使用更详细的片段语法将 key 属性添加到 react 片段,例如 react.fragment key={key} 。 更冗长的语法实现了相同的结果对元素列表进行分组,而不向 dom 添加额外的节点。 import react from react