如何创建自己的第一个React|如何创建自己的第一个React 页面
目录
- Rract是啥?
- 背景
- React脚手架
- JSX是什么
Rract是啥? React 是用于构建用户界面的 JavaScript 库
构建用户界面. User Interface,对咱们前端来说,简单理解为:HTML 页面
javscrtipt库。不是框架,是库, react 全家桶才是框架
react 全家桶:
react: 核心库react-dom: dom操作react-router:路由,redux:集中状态管理
背景 Rract最牛逼!全球使用最多
特点
声明式
用类似于html的语法来定义页面。react中通过数据驱动视图的变化,当数据发生改变react能够高效地更新并渲染DOM。
const list = [{ id: 1, name: '前端', salary: 100000 },{ id: 2, name: '后端', salary: 50 }]const title = ({list.map((item) => (
)- 班级{item.name}
))}
工资{item.salary}
文章图片
组件化(虽然每个框架都有)
组件是react中最重要的内容
组件用于表示页面中的部分内容
组合、复用多个组件,就可以实现完整的页面功能
学习一次,随处使用
使用react/rect-dom可以开发Web应用
使用react/react-native可以开发移动端原生应用(react-native)
使用react可以开发VR(虚拟现实)应用
React脚手架 从零开始 创建一个React项目
先全局安装脚手架工具包
命令:
npm i -g create-react-app
用脚手架工具来创建项目
命令:
create-react-app 项目名
文章图片
执行完毕后,我们会得到这样一个文件夹
文章图片
和Vue框架一样
1.src目录是我们写代码进行项目开发的目录
2.index.js是入口文件
在package.json中 有这么个命令
文章图片
可以输入
mpn run startyarn start
运行项目
文章图片
接下来我们删除src下的所有文件 新建一个 index.js
里面引入react 和 react-dom
// 导入react和react-domimport React from 'react'import ReactDOM from 'react-dom'
中间写我们的结构
// 创建元素const title = React.createElement('h1', {}, 'hello react(createElement写的)')
文章图片
但是createElement的效率太低了,我们可以使用jsx
JSX是什么
JSX:是 JavaScript XML的缩写。
- 在 JS 代码中书写 XML 结构
- 注意:JSX 不是标准的 JS 语法,是 JS 的语法扩展。脚手架中内置了 @babel/plugin-transform-react-jsx 包,用来解析该语法。
- React用它来创建 UI(HTML)结构
理解:我们之前用html写页面,现在是用jsx来写页面
const title= HELLO REACT(jsx写的)
文章图片
最终我们的代码会在
public/index.html
中渲染, 所以我们在底部添加这么一行代码,渲染到页面上 ,webpack会实时自动打包,并把代码嵌入到public/index.html
文件中,并执行。// 渲染react元素ReactDOM.render(title, document.getElementById('root'))
通过上面的代码 最终我们的页面都在 public/index.html里的 id=root 的div中渲染
文章图片
这样我们就写出了自己的第一个React页面
【如何创建自己的第一个React|如何创建自己的第一个React 页面】到此这篇关于如何创建自己的第一个React 页面的文章就介绍到这了,更多相关React 创建第一个页面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 尽力
- 考研英语阅读终极解决方案——阅读理解如何巧拿高分
- 如何寻找情感问答App的分析切入点
- 牛人进化+|牛人进化+ 按自己的意愿过一生
- mybatisplus如何在xml的连表查询中使用queryWrapper
- MybatisPlus使用queryWrapper如何实现复杂查询
- 放下心中的偶像包袱吧
- django-前后端交互
- 如何在Mac中的文件选择框中打开系统隐藏文件夹
- 漫画初学者如何学习漫画背景的透视画法(这篇教程请收藏好了!)