React组件

组件是React中的基本单位,在每个组件里面又封装了程序逻辑,通过reader标出界面片段或者回传一段描述,组件再通过React.renderComponent将组件展示在浏览器中。每个组件的编写中会绑定一些事件,这些事件是动态绑定的,这个以后分析。

注释:在React编写注释的时候一定要注意,我们创建一个单独的js文件,在老版本加上/** @jsx React.DOM */这段前面加上其他注释会有报错异常,在新版本的react.js去掉了对这个注释的定义,可以不写一样执行。

看下代码:

/**
* Created by 13121528 on 2014/10/15.
*/
/**
* @jsx React.DOM
*/
var KlmNode = React.createClass({
render:function(){
return (<p>hello,sss</p>);
}
}); React.renderComponent(<KlmNode />,document.getElementById('container'));

从上面代码分析运行结果浏览器会报错“”

去掉/** @jsx React.DOM */前端的注释就运行正常了。在React官网也提到了注释问题,格式限定的非常严格。

在renderComponent函数的第一个参数是组件,这个命名可以任意:但你要针对这个命名创建一个的组件,如下代码:

/**
* @jsx React.DOM
*/ var hello = React.createClass({
render:function(){
return (<div className="ss">{this.props.title}</div>);
}
}); React.renderComponent(<hello title="Hello!" />,document.getElementById('container'));

运行结果是:

注:最新版本的React.js现在区分自定义模板名称了,上面小写的<hello> 首字母必须大写才能执行<Hello>,不然会失效。

通过React.createClass方式放回一个<div>的HTML Dom结构,其实<hello />标签就是return <div>,注意这里给创建组件添加样式需要通过"className"来定义,一般我们给HTML dom添加样式用class,而在React框架中则是className,或者直接对dom添加style,这个叫“内联样式”,在上面代码中可以给自定义组件添加属性,这个属性名称可以任意命名,跟平常自定义HTML dom属性一样,怎么获取值呢?在React中是用{this.props.*}的方式获取自定义属性的值。

刚才提到内联样式,在React中是这样呈现它的写法的,看下面代码:

/**
* @jsx React.DOM
*/
var navcss ={
margin:' 0 auto',
width:'95%',
height:'30px;',
lineHeight:'30px',
background:'cornflowerblue',
textAlign:'center'
}
var Nav = React.createClass({
render:function(){
return(
<div style={navcss}>
var NB = new Beer();
</div>
);
}
}); React.renderComponent(<Nav />,document.getElementById('navigation'));

我定义一个navcss变量里面封装了css样式,我只要在return dom中加上style={"自定义css样式变量"}就可以呈现在浏览器中了。注释:这里的css样式属性是驼峰式的命名,如(lineHeight,textAlign...);

在创建一个组件的时候return dom的时候,在里面可以再定义一组,如下段代码:

/**
* @jsx React.DOM
*/
var navcss ={
margin:' 0 auto',
width:'95%',
padding:'10px 0px 10px 0px;',
lineHeight:'50px',
background:'cornflowerblue',
textAlign:'center',
color:'#fff',
fontWeight:'bold',
fontSize:'50px',
textShadow:'0 0 1px #f6f6f6,0 0 5px #f6f6f6,0 0 15px #f6f6f6,0 0 20px #0090d9,0 0 25px #0090d9,0 0 30px #0090d9,0 0 50px #0090d9,0 0 80px #0090d9,0 0 100px #0090d9,0 0 150px #0090d9'
}
var navEmCss = {
display:'block',
width:'30px',
height:'30px',
float:'right',
border:'1px solid #000',
position:'relative'
} var Nav = React.createClass({
render:function(){
return(
<div style={navcss}>
var NB = new Bee();
<NavEm />
</div>
);
}
}); var NavEm = React.createClass({
render:function(){
return(
<em style={navEmCss} />
)
}
}); React.renderComponent(<Nav />,document.getElementById('navigation'));

运行结果如图:

右边有一个黑色的小框就是嵌套添加的组件内容。这里只是介绍React可以这样创建一个Dom树结构,个人在开发过程中不怎么会这样去做,我觉得这样会增加js代码量的开发。

注:在创建React组件的时候,如果里面DOM节点会自动给其添加一个属性data-reactid=".0.0",在这里提示一下!

React组件的更多相关文章

  1. React 组件性能优化探索实践

    转自:http://www.tuicool.com/articles/Ar6Zruq React本身就非常关注性能,其提供的虚拟DOM搭配上Diff算法,实现对DOM操作最小粒度的改变也是非常的高效. ...

  2. webpack 打包一个简单react组件

    安装Webpack,并加载一个简单的React组件 全局的npm模块安装: npm install -g webpack 安装jsx-loader npm install --save-dev jsx ...

  3. React 组件性能优化

    React组件性能优化 前言 众所周知,浏览器的重绘和重排版(reflows & repaints)(DOM操作都会引起)才是导致网页性能问题的关键.而React虚拟DOM的目的就是为了减少浏 ...

  4. React组件属性部类(propTypes)校验

    React组件属性类型(propTypes)校验 Prop 验证 随着应用不断变大,保证组件被正确使用变得非常有用.为此我们引入propTypes.React.PropTypes 提供很多验证器 (v ...

  5. 使用reflux进行react组件之间的通信

    前言 组件之间为什么要通信?因为有依赖. 那么,作为React组件,怎么通信? React官网说, 进行 父-子 通信,可以直接pass props. 进行 子-父 通信,往父组件传给子组件的函数注入 ...

  6. 野心勃勃的React组件生命周期

    当你还在写着Angular指令,过滤器,注入,服务,提供者,视图模版的时候,是不是觉得很烦,好在这个时候,React已经神一样的出现在历史舞台. React组件    React实现了UI=Fn(St ...

  7. React组件性能优化

    转自:https://segmentfault.com/a/1190000006100489 React: 一个用于构建用户界面的JAVASCRIPT库. React仅仅专注于UI层:它使用虚拟DOM ...

  8. React组件生命周期过程说明

    来自kiinlam github94 实例化 首次实例化 getDefaultProps getInitialState componentWillMount render componentDidM ...

  9. React组件系统、props与状态(state)

     多个组件合成一个组件: var style = { fontSize: 20, color: '#ff0000' }; var WebSite = React.createClass({ rende ...

随机推荐

  1. 两个viewport的故事(第二部分)

    原文:http://www.quirksmode.org/mobile/viewports2.html 在这个迷你系列的文章里边我将会解释viewport,以及许多重要元素的宽度是如何工作的,比如&l ...

  2. jquery学习笔记---requirejs 和模块化编程

    http://www.cnblogs.com/lisongy/p/4711056.html jquery模块化编程:http://www.cnblogs.com/digdeep/p/4602460.h ...

  3. CLR via C#(14)-可空值类型,关于?和??的故事

    我们都知道,值类型是不能为Null的,但是在实际应用中有些情形却需要将值类型置为null.因此,CLR中引用了可空值类型的用法.今天的文章中见到最多的符号估计就是?了吧. ?——初识可空值类型 1.  ...

  4. 重温WCF之消息拦截与篡改(八)

    我们知道,在WCF中,客户端对服务操作方法的每一次调用,都可以被看作是一条消息,而且,可能我们还会有一个疑问:如何知道客户端与服务器通讯过程中,期间发送和接收的SOAP是什么样子.当然,也有人是通过借 ...

  5. 发现一php木马代码

    <?php ;//无需验证密码! $shellname='hello~地球~猴子星球欢迎你 '; define('myaddress',__FILE__); error_reporting(E_ ...

  6. Extjs ComboBox 动态选中第一项

    有时候我们希望通过Store加载过来的数据,ComboBoxItem能够选择第一条数据作为默认数据,我们可以这么操作: var storeinfo = Ext.create('Ext.data.Sto ...

  7. 学习一下《JavaEE开发的颠覆者 Spring Boot实战 》

    SPRING,绕不过去的.

  8. 学习ASP.NET缓存机制

    缓存是大型BS架构网站的性能优化通用手段,之前知道有这个概念,并且也知道很重要,但是一直没静下心来了解.这次借着学习PetShop源码的机会熟悉一下ASP.NET基本的缓存机制(生产环境中的真实缓存有 ...

  9. 算法系列:Reservoir Sampling

    copyright © 1900-2016, NORYES, All Rights Reserved. http://www.cnblogs.com/noryes/ 欢迎转载,请保留此版权声明. -- ...

  10. SSAS Cube 维度成员关系Rigid 和 Flexible

    维度成员关系指示成员关系是否随时间而更改.  值为 Rigid 和 Flexible,前者表示成员之间的关系不随时间而更改,后者表示成员之间的关系随时间而更改. 默认值为 Flexible.  指定适 ...