React是一款颠覆式的前端解决方案,其创新的编程思想以及衍生出来的一些生态圈技术可以说是引领了整个前端的发展。
每一种新事物的出现都是为了解决某些问题,React也不例外。所以了解了它要解决的问题,就能更好的接受这个新的框架。在React出现之前,原生的JavaScript有哪些痛点:
-
原生JavaScript操作DOM繁琐、效率低。 -
使用JavaScript直接操作DOM,浏览器会进行大量的重绘重排。 -
原生JavaScript没有组件化编码方案,代码效率低。
为什么要选择React?
-
其声明式的语法可以让你直观的去描述和组织复杂的界面逻辑 -
其繁荣的生态圈则为解决各种问题带来了大量的最佳实践 -
其活跃的技术社区则让你在遇到问题的时候 能快速得到帮助 -
React技术栈不仅可以让你从容面对大型项目的开发其编程思想还可以运用到React Native进行原生开发 -
其server端渲染的技术则可以让你进行同构的后端开发
元素是构成 React 应用的最小单位,它用于描述屏幕上输出的内容。
const element = Hello, world!
;
与浏览器的 DOM 元素不同,React 当中的元素事实上是普通的对象,React DOM 可以确保 浏览器 DOM 的数据内容与 React 元素保持一致。
将元素渲染到 DOM 中
首先我们在一个 HTML 页面中添加一个 id=”example” 的
:
"example">
在此 div 中的所有内容都将由 React DOM 来管理,所以我们将其称为 “根” DOM 节点。
我们用 React 开发应用时一般只会定义一个根节点。但如果你是在一个已有的项目当中引入 React 的话,你可能会需要在不同的部分单独定义 React 根节点。
要将React元素渲染到根DOM节点中,我们通过把它们都传递给 ReactDOM.render() 的方法来将其渲染到页面上:
实例
const element =
Hello, world!
; ReactDOM.render( element, document.getElementById('example') );
更新元素渲染
React 元素都是不可变的。当元素被创建之后,你是无法改变其内容或属性的。
目前更新界面的唯一办法是创建一个新的元素,然后将它传入 ReactDOM.render() 方法:
来看一下这个计时器的例子:
实例
function tick() { const element = (
Hello, world!
现在是 {new Date().toLocaleTimeString()}.
以上实例通过 setInterval() 方法,每秒钟调用一次 ReactDOM.render()。
我们可以将要展示的部分封装起来,以下实例用一个函数来表示:
实例
function Clock(props) { return (
Hello, world!
现在是 {props.date.toLocaleTimeString()}.
除了函数外我们还可以创建一个 React.Component 的 ES6 类,该类封装了要展示的元素,需要注意的是在 render() 方法中,需要使用 this.props 替换 props:
实例
class Clock extends React.Component { render() { return (
Hello, world!
现在是 {this.props.date.toLocaleTimeString()}.
以上就是良许教程网为各位朋友分享的Linu系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !