前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >React 基础

React 基础

作者头像
用户10169043
发布2022-11-18 14:06:57
2.1K0
发布2022-11-18 14:06:57
举报
文章被收录于专栏:从0到1前端开发

React 概述

React 介绍

在这里插入图片描述
在这里插入图片描述

react是一个用于构建用户界面的 JavaScript 库 react官网(https://reactjs.org/) react中文网(https://zh-hans.reactjs.org/)

  • React 是一个用于构建用户界面(UI,对咱们前端来说,简单理解为:HTML 页面)的 JavaScript 库
  • 如果从mvc的角度来看,React仅仅是视图层(V)的解决方案。也就是只负责视图的渲染,并非提供了完整了M和C的功能
  • react/react-dom/react-router/redux: 框架
  • React 起源于 Facebook 内部项目(News Feed,2011),后又用来架设 Instagram 的网站(2012),并于 2013 年 5 月开源react介绍
  • React 是最流行的前端开发框架之一,其他:Vue、Angular 等等框架对比

react特点

声明式UI

你只需要描述UI(HTML)看起来是什么样的,就跟写HTML一样

代码语言:javascript
复制
const jsx = <div className="app">
    <h1>Hello React! 动态数据变化:{count}</h1>
</div>

声明式对应的是命令式,声明式关注的是what,命令式关注的是how

组件化

  • 组件是react中最重要的内容
  • 组件用于表示页面中的部分内容
  • 组合、复用多个组件,就可以实现完整的页面功能
在这里插入图片描述
在这里插入图片描述

学习一次,随处使用

  • 使用react/rect-dom可以开发Web应用
  • 使用react/react-native可以开发移动端原生应用(react-native) RN 安卓 和 ios应用 flutter
  • 使用react可以开发VR(虚拟现实)应用(react360)
在这里插入图片描述
在这里插入图片描述

从你的角度看 React 特点:

  • 工资高、大厂必备(阿里在用)
  • 工资高、大厂必备(字节跳动在用)
  • 工资高、大厂必备(百度、腾讯、京东、蚂蚁金服、拼多多、美团、外企、银行等都在用)

React 脚手架(CLI)

  • React 脚手架的介绍
  • 使用 React 脚手架创建项目
  • 项目目录结构调整

React 脚手架的介绍

  • 脚手架:为了保证各施工过程顺利进行而搭设的工作平台
  • 对于前端项目开发来说,脚手架是为了保证前端项目开发过程顺利进行而搭设的开发平台
  • 脚手架的意义:
    • 现代的前端开发日趋成熟,需要依赖于各种工具,比如,webpack、babel、eslint、sass/less/postcss等
    • 工具配置繁琐、重复,各项目之间的配置大同小异
    • 开发阶段、项目发布,配置不同
      • 项目开始前,帮你搭好架子,省去繁琐的 webpack 配置
      • 项目开发时,热更新、格式化代码、git 提交时自动校验代码格式等
      • 项目发布时,一键自动打包,包括:代码压缩、优化、按需加载等

使用 React 脚手架创建项目

  • 命令:npx create-react-app react-basic
    • npx create-react-app 是固定命令,create-react-app 是 React 脚手架的名称
    • react-basic 表示项目名称,可以修改
  • 启动项目:yarn start or npm start
  • npx 是 npm v5.2 版本新添加的命令,用来简化 npm 中工具包的使用
    • 原始:1 全局安装npm i -g create-react-app 2 在通过脚手架的命令来创建 React 项目
    • 现在:npx 调用最新的 create-react-app 直接创建 React 项目

项目目录结构说明和调整

  • 说明:
    • src 目录是我们写代码进行项目开发的目录
    • 查看 package.json 两个核心库:reactreact-dom(脚手架已经帮我们安装好,我们直接用即可)
  • 调整:
    1. 删除 src 目录下的所有文件
    2. 创建 index.js 文件作为项目的入口文件,在这个文件中写 React 代码即可

React 的基本使用

基本步骤

  • 使用步骤
代码语言:javascript
复制
- 导入react和react-dom     
- 创建react元素(虚拟DOM)
- 渲染react元素到页面中
  • 导入react和react-dom
代码语言:javascript
复制
// 导入react和react-dom
import React from 'react'
import ReactDOM from 'react-dom'
  • 创建react元素
代码语言:javascript
复制
// 创建元素
const title = React.createElement('h1', null, 'hello react')
  • 渲染react元素到页面
代码语言:javascript
复制
// 渲染react元素
ReactDOM.render(title, document.getElementById('root'))

练习

  1. 使用react,生成以下结构
代码语言:javascript
复制
<div id="box" class="demo">这是一个react案例</div>
  1. 生成结构2
代码语言:javascript
复制
<ul class="list">
    <li>香蕉</li>
    <li>橘子</li>
    <li>苹果</li>
</ul>

小结

  • 能够说出react是什么
    • 是用于构建用户界面的javascript库
  • 能够说出react的特点
    • 声明式ui
    • 组件化
    • 一处学习,多次使用 react-dom react-native
  • 能够掌握react的基本用法
  • 能够使用react脚手架
    • yarn global add create-react-app

JSX

JSX的基本使用

createElement的问题

  • 繁琐不简洁
  • 不直观,无法一眼看出所描述的结构
  • 不优雅,开发体验不好
在这里插入图片描述
在这里插入图片描述

JSX简介

JSXJavaScript XML的简写,表示了在Javascript代码中写XML(HTML)格式的代码

优势:声明式语法更加直观,与HTML结构相同,降低学习成本,提高开发效率。

JSX是react的核心内容

注意:JSX 不是标准的 JS 语法,是 JS 的语法扩展。脚手架中内置的 @babel/plugin-transform-react-jsx 包,用来解析该语法。

在这里插入图片描述
在这里插入图片描述

使用步骤

代码语言:javascript
复制
- 导入react和reactDOM包
- 使用jsx语法创建react元素
- 把react元素渲染到页面中
  • 导入react和reactDOM
代码语言:javascript
复制
// 导入react和react-dom
import React from 'react'
import ReactDOM from 'react-dom'
  • 创建react元素
代码语言:javascript
复制
// 创建元素
const title = <h1 title="哈哈"></h1>
  • 渲染元素
代码语言:javascript
复制
// 渲染元素
ReactDOM.render(title, document.getElementById('root'))

JSX注意点

  • 只有在脚手架中才能使用jsx语法
    • 因为JSX需要经过babel的编译处理,才能在浏览器中使用。脚手架中已经默认有了这个配置。
  • JSX必须要有一个根节点, <></> <React.Fragment></React.Fragment>
  • 没有子节点的元素可以使用/>结束
  • JSX中语法更接近与JavaScript
    • class =====> className
    • for========> htmlFor
  • JSX可以换行,如果JSX有多行,推荐使用()包裹JSX,防止自动插入分号的bug

使用prettier插件格式化react代码

  • 安装插件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SFkbkk9p-1668350764104)(images/image-20200907165515629-1629115818044.png)]

  • 添加prettier的配置
代码语言:javascript
复制
// 保存到额时候用使用prettier进行格式化
"editor.formatOnSave": true,
// 不要有分号
"prettier.semi": false,
// 使用单引号
"prettier.singleQuote": true,
// 默认使用prittier作为格式化工具
"editor.defaultFormatter": "esbenp.prettier-vscode",

JSX中嵌入JavaScript表达式

在jsx中可以在{}来使用js表达式

  • 基本使用
代码语言:javascript
复制
const name = 'zs'
const age = 18
const title = (
  <h1>
    姓名:{name}, 年龄:{age}
  </h1>
)
  • 可以访问对象的属性
代码语言:javascript
复制
const car = {
    brand: '玛莎拉蒂'
}
const title = (
  <h1>
    汽车:{car.brand}
  </h1>
)
  • 可以访问数组的下标
代码语言:javascript
复制
const friends = ['张三', '李四']
const title = (
  <h1>
    汽车:{friends[1]}
  </h1>
)
  • 可以使用三元运算符
代码语言:javascript
复制
const gender = 18
const title = (
  <h1>
    性别:{age >= 18? '是':'否'}
  </h1>
)
  • 可以调用方法
代码语言:javascript
复制
function sayHi() {
  return '你好'
}
const title = <h1>姓名:{sayHi()}</h1>
  • JSX本身
代码语言:javascript
复制
const span = <span>我是一个span</span>
const title = <h1>盒子{span}</h1>
  • JSX中的注释
代码语言:javascript
复制
{/* 这是jsx中的注释 */}   推荐快键键 ctrl + /
  • 不要出现语句,比如if for

条件渲染

在react中,一切都是javascript,所以条件渲染完全是通过js来控制的

  • 通过判断if/else控制
代码语言:javascript
复制
const isLoding = false
const loadData = () => {
  if (isLoding) {
    return <div>数据加载中.....</div>
  } else {
    return <div>数据加载完成,此处显示加载后的数据</div>
  }
}

const title = <div>条件渲染:{loadData()}</div>
  • 通过三元运算符控制
代码语言:javascript
复制
const isLoding = false
const loadData = () => {
  return isLoding ? (
    <div>数据加载中.....</div>
  ) : (
    <div>数据加载完成,此处显示加载后的数据</div>
  )
}
  • 逻辑运算符
代码语言:javascript
复制
const isLoding = false
const loadData = () => {
  return isLoding && <div>加载中...</div>
}

const title = <div>条件渲染:{loadData()}</div>

vscode配置自动补全

代码语言:javascript
复制
// 当按tab键的时候,会自动提示
"emmet.triggerExpansionOnTab": true,
"emmet.showAbbreviationSuggestions": true,
// jsx的提示
"emmet.includeLanguages": {
  "javascript": "javascriptreact"
}

列表渲染

我们经常需要遍历一个数组来重复渲染一段结构 在react中,通过map方法进行列表的渲染

  • 列表的渲染
代码语言:javascript
复制
const songs = ['温柔', '倔强', '私奔到月球']

const list = songs.map(song => <li>{song}</li>)

const dv = (
  <div>
    <ul>{list}</ul>
  </div>
)
  • 直接在JSX中渲染
代码语言:javascript
复制
const songs = ['温柔', '倔强', '私奔到月球']

const dv = (
  <div>
    <ul>{songs.map(song => <li>{song}</li>)}</ul>
  </div>
)
  • key属性的使用
代码语言:javascript
复制
const dv = (
  <div>
    <ul>
      {songs.map(song => (
        <li key={song}>{song}</li>
      ))}
    </ul>
  </div>
)

注意:列表渲染时应该给重复渲染的元素添加key属性,key属性的值要保证唯一

注意:key值避免使用index下标,因为下标会发生改变

样式处理

行内样式-style

代码语言:javascript
复制
const dv = (
  <div style={{ color: 'red', backgroundColor: 'pink' }}>style样式</div>
)

类名-className

代码语言:javascript
复制
// 导入样式
import './base.css'
const dv = <div className="title">style样式</div>

base.css样式文件

代码语言:javascript
复制
.title {
  text-align: center;
  color: red;
  background-color: pink;
}

总结

  • JSX是React的核心内容
  • JSX表示在JS代码中书写HTML结构,是React声明式的体现
  • 使用JSX配合嵌入的JS表达式,条件渲染,列表渲染,可以渲染任意的UI结构
  • 结果使用className和style的方式给JSX添加样式
  • React完全利用JS的语言自身的能力来编写UI,而不是造轮子增强HTML的功能。(对比VUE)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-11-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • React 概述
    • React 介绍
      • react特点
        • 声明式UI
        • 组件化
        • 学习一次,随处使用
      • React 脚手架(CLI)
        • React 脚手架的介绍
        • 使用 React 脚手架创建项目
        • 项目目录结构说明和调整
      • React 的基本使用
        • 基本步骤
        • 练习
      • 小结
      • JSX
        • JSX的基本使用
          • createElement的问题
          • JSX简介
          • 使用步骤
          • JSX注意点
        • 使用prettier插件格式化react代码
          • JSX中嵌入JavaScript表达式
            • 条件渲染
              • vscode配置自动补全
                • 列表渲染
                  • 样式处理
                    • 行内样式-style
                    • 类名-className
                  • 总结
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档