Ch03 React/JSX/Component 簡介
Component PropType 防呆机制
在 React 设计时除了提供 props 预设值设定(Default Prop Values)外,也提供了 Prop 的验证(Validation)机制,让整个 Component 设计更加稳健:
// render 是 Class based 组件唯一必须的方法(method)
render() {
return (
<div>Hello, World!</div>
);
}
}
// PropTypes 验证,若传入的 props type 不符合将会显示错误MyComponent.propTypes = {
todo: React.PropTypes.object,
name: React.PropTypes.string,
}
// Prop 预设值,若对应 props 没传入值将会使用 default 值MyComponent.defaultProps = {
todo: {},
name: '',
Component 就像个状态机(State Machine),而且也有生命周期(Life Cycle)
setState()
修改)和 props(由父元素传入),Component 会出现对应的显示结果。而人有生老病死,组件也有生命周期。透过操作生命周期处理函数,可以在对应的时间点进行 Component 需要的处理,关于更详细的组件生命周期介绍我们会再下一个章节进行更一步说明。一律重绘(Always Redraw)和单向资料流(Unidirectional Data Flow)
在 JavaScript 里写 CSS:Inline Style
在 React Component 中 CSS 使用 Inline Style 写法,全都封装在 JavaScript 当中:
color: 'red',
backgroundImage: 'url(' + imgUrl + ')',
};
ReactDOM.render(<div style={divStyle}>Hello World!</div>, document.getElementById('app'));
Declarative
(注重 what to),而非命令式 Imperative
(注重 how to)的程式撰写方式:以 Facebook 上面按赞功能来说,若是命令式 Imperative
写法大约会是长这样:
if(userLikes()) {
if(!hasBlueLike()) {
removeGrayLike();
addBlueLike();
}
} else {
if(hasBlueLike()) {
removeBlueLike();
addGrayLike();
}
}
若是声明式 Declarative
则是会长这样:
return (<BlueLike />);
} else {
return (<GrayLike />);
map 方法可以方便的迭代数组,map 方法会迭代数组中的每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组。注意,这个方法不会改变原始数组。
在我们的例子中,回调函数只有一个参数,即数组中元素的值 (val 参数) ,但其实,你的回调函数也可以支持多个参数,譬如:元素的索引index、原始数组arr。
使用 map 方法来为 oldArray 中的每一项增加3,并且在 newArray 中保存它们。 oldArray 不应该被改变。
代码:
var oldArray = [1,2,3,4,5];
var newArray = oldArray.map(function(val){return val+3;});
3. 转换成 JavaScript
JSX 最终会转换成浏览器可以读取的 JavaScript,以下为其规则:
React.createElement(
string/ReactClass, // 表示 HTML 元素或是 React Component
[object props], // 属性值,用物件表示
[children] // 接下来参数皆为元素子元素
)
解析前(特别注意在 JSX 中使用 JavaScript 表达式时使用 {}
括起,如下方范例的 text
,里面对应的是变数。若需希望放置一般文字,请加上 ''
):
var text = 'Hello React';
<h1>{text}</h1><h1>{'text'}</h1>
解析完后:
var text = 'Hello React';
React.createElement("h1", null, "Hello React!");
render
方法中只能回传一个根节点(Root Nodes)。例如:若有多个 <div>
要 render
请在外面包一个 Component 或 <div>
、<span>
元素5. 属性
class
和 for
由于为 JavaScript 保留关键字用法,因此在 JSX 中使用 className
和 htmlFor
替代。render() {
return (
<div className="message">
<p>Hello React!</p>
</div>
);
}
}
Boolean 属性
在 JSX 中预设只有属性名称但没设值为 true
,例如以下第一个 input 标签 disabled
虽然没设值,但结果和下面的 input 为相同:
<input type="button" disabled />;
<input type="button" disabled={true} />;
反之,若是没有属性,则预设预设为 false
:
6. 扩展属性
在 ES6 中使用 ...
是迭代物件的意思,可以把所有物件对应的值迭代出来设定属性,但要注意后面设定的属性会盖掉前面相同属性:
style: "width:20px",
className: "main",
value: "yo",
}
<HelloMessage {...props} value="yo" />
7. 自定义属性
若是希望使用自定义属性,可以使用 data-
:
8. 显示 HTML
9. 样式使用
在 JSX 中使用外观样式方法如下,第一个 {}
是 JSX 语法,第二个为 JavaScript 物件。与一般属性值用 -
分隔不同,为驼峰式命名写法:
10. 事件处理
事件处理为前端开发的重头戏,在 JSX 中透过 inline 事件的绑定来监听并处理事件(注意也是驼峰式写法),更多事件处理方法请参考官网
Ch03 React/JSX/Component 簡介的更多相关文章
- [React] Spread Component Props in JSX with React
You often find duplication between the name of a prop and a variable you will assign to the prop. JS ...
- React(JSX语法)-----JSX基本语法
JSX------HTML tags vs React Components: 1.To render a html tag,just use lower-case tag names in JSX; ...
- 在react jsx中,为什么使用箭头函数和bind容易出现问题
在之前的文章中,已经说明如何避免在react jsx中使用箭头函数和bind(https://medium.freecodecamp.o... 但是没有提供一个清晰的demo展示为什么要这样做. 现在 ...
- Airbnb React/JSX 编码规范
Airbnb React/JSX 编码规范 算是最合理的React/JSX编码规范之一了 内容目录 基本规范 Class vs React.createClass vs stateless 命名 声明 ...
- React:JSX 深入
React入门的的时候,我们(我自己啦)喜欢都跟着例子来,用标签的语法写JSX,比如:<Mycomponent key={this.props.id} onClick={this.props ...
- 【go】脑补框架 Express beego tornado Flux reFlux React jsx jpg-ios出品
http://goexpresstravel.com/ 今天 Express 的作者 TJ Holowaychuk 发了一篇文章,正式宣告和 Node.js 拜拜了,转向 Go 语言. Go vers ...
- Scripting Languages 簡介
Scripting Languages 簡介 何謂 Scripting? 命令稿語言 scripting language 是什麼? 很難給一個嚴格的定義; 不妨看看最具代表性的幾個例子: perl, ...
- React & styled component
React & styled component https://www.styled-components.com/#your-first-styled-component tagged t ...
- Source Tree 簡介
Table of Contents 1. 什麼是 Source Tree ? 1.1. 下載 1.2. SourceTree 介面簡介 1.3. git 指令/狀態圖 2. SourceTrees 超 ...
随机推荐
- CodeForces 367E Sereja and Intervals
CodeForces 3 67E (109 + 7). Two ways are considered distinct if there is such j(1 ≤ j ≤ n), that the ...
- Ajax提交post请求返回404错误
最近使用ajax提交表单的时候,发现无法执行success函数,后台的代码也正常执行了,但是就是无法执行success函数,执行error函数,返回的错误代码时404.显然是找不到请求的url. 可是 ...
- vim下多行注释与解注释
1.多行注释 (1)按esc进入命令行模式 (2)按下Ctrl+v,进入区块模式,并使用上下键选择需要注释的多行 (3)按下“I”(大写)键,进入插入模式 (4)输入注释符(“//”或“#”等) (5 ...
- 使用pymongo.find查询很慢的解决方式
1.前言: mongodb部署在阿里云服务器, mongodb中collection存储了百万条记录. 需求:优化查询指定时间段内的所有数据的查询时间,结果有百万级别. 最初:313587条记录耗时: ...
- 数据结构之中序遍历转兴许遍历(JAVA实现)(二)
算法流程: 主要分为四步: 1.当前字符为数字或者字母,则直接输出 2.当前字符为).则在栈中匹配输出.一直匹配到),则停止输出(就是将)及其顶上的元素所有弹出来输出) 3.当前字符为操作符.则比較当 ...
- Ubuntu 13.10 安装 TeX Live 2013
注:笔者也是刚刚接触TeX系统,水平有限,若有疏漏之处还望指正. 中文解决方案 对于LaTeX中文排版,比较方便有这样的几种解决方案:LaTeX+CJK / LaTeX+XeTeX / CTeX.其中 ...
- 行政区划代码(JSON版本)2018年8月
字段:regioncode //行政区划代码 regionname //行政区划名称 pcode //行政区划上一级代码 [{ "REGIONCODE": "11000 ...
- 【转】Android 关闭多个视图Intent.FLAG_ACTIVITY_CLEAR_TOP用法
如果已经启动了四个Activity:A,B,C和D.在D Activity里,我们要跳到B Activity,同时希望C finish掉, 可以在startActivity(intent)里的inte ...
- java Map 转 List
public static void testMapVoid () { Map map = new HashMap(); map.put("a", "a1"); ...
- Bing Maps进阶系列三:使用地图图像服务(ImageryService)
Bing Maps进阶系列三:使用地图图像服务(ImageryService) 地图图像服务(ImageryService)提供了根据地理位置(经度和纬度)坐标和地图的缩放级别解析出对应于地图图片系统 ...