5分钟入门react教程(提供源码)
xsobi 2024-12-10 21:36 1 浏览
提供1个例子,带领初学者快速了解react基础开发,开始入门
名词解析:
- React: 是一个用于构建用户界面的 JavaScript 库
- JSX: React 中建议使用jsx语法,jsx最终会被转为普通 JavaScript 函数
- TypeScript: 是JavaScript 的一个类型超集,TypeScript 可以在构建时发现 bug 和错误,这样程序运行时就可以避免此类错误,.ts 是默认的文件扩展名,而 .tsx 是一个用于包含 JSX 代码的特殊扩展名
- Node.js: 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。
创建一个react app 项目
GitHub地址: https://github.com/itainf/demo-react
体验地址:http://wojson.com/demo/demo-react/hello.html
一. 安装nodejs
nodejs 是开发JavaScript 程序的运行环境,必须先安装
Node.js下载地址:https://nodejs.org/zh-cn/download/
二. 创建react 项目
安装好nodejs后,在nodejs环境创建一个react 项目
执行命令:
npx create-react-app demo-react
npx npm 5.2+ 的package 运行工具
执行完提示:
执行完提示:
yarn start
Starts the development server.
yarn build
Bundles the app into static files for production.
?
yarn test
Starts the test runner.
?
yarn eject
Removes this tool and copies build dependencies, configuration files
and scripts into the app directory. If you do this, you can’t go back!
?
We suggest that you begin by typing:
?
cd demo-react
yarn start
目录结构如下:
|-- README.md
|-- node_modules
|-- package.json
|-- public
|-- src
`-- yarn.lock
执行 yarn build 会在 build 文件夹内生成你应用的优化版本.
执行命令会自动生成 README.md 文件,了解更多信息可参考该文件
三.第一个react程序
import PropTypes from 'prop-types';
import React, { useState } from 'react';
import ReactDOM, { render } from 'react-dom'
/*
构建一个函数组件(注意组件类只能包含一个顶层标签)
1. 如何创建一个函数组件
2. 如何使用 useState 创建一个变量
3. 如何传递参数给组件
*/
const HelloMessage = props => {
/*
1. props 包含组件传递的参数,props.name 获取到使用组件 <HelloMessage name='小帅哥' /> 的name
2. 使用 State Hook
声明 count 变量
申明 setCount 用于改变变量值
*/
const [count, setCount] = useState(0);
/*
固定写法,返回一个html串
setCount(count + 1) 更新count的值,自动重新渲染组件
*/
return (<div>
<h1>你好,{props.name}! </h1>
<h2>你点了我: {count}次 </h2>
<button onClick={() => setCount(count + 1)}>
点击
</button>
</div>);
} ;
// 声明 name 参数类型是 string 类型
HelloMessage.propTypes = {
name: PropTypes.string
};
//创建div 挂载到body
const appTarget = document.createElement('div');
document.body.appendChild(appTarget);
// 挂载组件到到div
// name='小帅哥' 传递参数给组件
ReactDOM.render(<HelloMessage name='小帅哥' />, appTarget);
项目根目录执行:yarn start
访问:http://127.0.0.1:8601/hello.html
相关推荐
- 【互联网那些事】高效开发Android App的10个建议
-
假如要GooglePlay上做一个最失败的案例,那最好的秘诀就是界面奇慢无比、耗电、耗内存。接下来就会得到用户的消极评论,最后名声也就臭了。即使你的应用设计精良、创意无限也没用。 耗电或者内存...
- 手机APP开发方式有哪些? 手机app的开发模式有哪三种?
-
微信小程序开发定制_软件开发_APP开发_网站制作-优软软件开发...
- Android开发入门(一):Android系统简介
-
Android系统是Google公司在2008年推出的一款智能移动设备操作系统,通过不断地版本迭代,目前已经推出到Android11版本了。Android系统广泛应用在手机、平板、电视等各种电子设...
- 物联网app开发流程 物联网app开发工具
-
现在随着科技的发展,很多产品都想用一个手机app去显示他的参数数据或者通过手机app去控制它。但是很多人不知道他的流程。今天我就来说下物联网app开发流程。首先需要把物联网app开发流程分2个步骤,一...
- Android开发进阶 | 如何学习 Android Framework?
-
大部分有“如何学习Framework源码”这个疑问的,应该大都是应用层开发。应用层是被Framework层调用执行的,知道自己的代码是怎么被调用的,才能理解程序的本质,理解本质有助于解决遇到的...
- 快速实现APP混合开发(Hybrid App开发)攻略
-
前言:...
- 三个阶段带你了解一款app开发的完整流程
-
第一个阶段需求阶段:1.需求讨论--开发类型、开发平台、具体的产品功能需求、项目预计完成时间、预算2.需求评估--确认合作后评估具体的预算3.界面设计--设计部门进行产品界面设计,形成效果图...
- Android 开发中文引导-应用小部件
-
应用小部件是可以嵌入其它应用(例如主屏幕)并收到定期更新的微型应用视图。这些视图在用户界面中被叫做小部件,并可以用应用小部件提供者发布。可以容纳其他应用部件的应用组件叫做应用部件的宿主(1)。下面的截...
- 手机软件开发从零开始【Android第2篇Hello】
-
Hello,朋友们我们又见面了。上一篇我们讲到了《Android开发环境搭建【Android基础第1篇】》,错过的朋友可以点击文章末尾的“阅读原文”查看。另外需要下载JDK和ADT-bundle工具的...
- 「全栈工程师之梦的开始--安卓开发(二)」开发安卓app
-
在配置好jdk开发环境、安装好开发工具Androidstudio后,我们就可以开始开发安卓app了。首先,我们需要先了解下android的术语。...
- 二、Android界面开发 android 开发
-
学习目标了解Android常用布局了解Android常用控件...
- 如何开发一款APP既快捷也简便 开发一款app的步骤
-
具体较为简单的步骤可以选择用androidstudio开发app1、打开软件,在菜单中选择file-》newproject打开创建向导。2、配置项目,确定各个名称和存放项目的存放路径;Applic...
- 安卓开发中的“Android高手”,需要具备哪些技术?
-
前言成为一名安卓开发者很容易,但是要成为一名“Android高手”却不那么容易;...
- 移动开发(一):使用.NET MAUI开发第一个安卓APP
-
对于工作多年的C#程序员来说,近来想尝试开发一款安卓APP,考虑了很久最终选择使用.NETMAUI这个微软官方的框架来尝试体验开发安卓APP,毕竟是使用VisualStudio开发工具,使用起来也...
- 微软推出PowerApps:零基础开发Win10/iOS/安卓企业应用
-
IT之家讯微软今天面向企业宣布了全新的应用开发解决方案PowerApps,让Windows(包括Win10)、iOS以及安卓应用的开发和分发变得更加简单。PowerApps的用户界面与Office办...
- 一周热门
- 最近发表
- 标签列表
-
- grid 设置 (58)
- 移位运算 (48)
- not specified (45)
- patch补丁 (31)
- 导航栏 (58)
- context xml (46)
- scroll (43)
- element style (30)
- dedecms模版 (53)
- vs打不开 (29)
- nmap (30)
- c 视频教程下载 (33)
- paddleocr (28)
- listview排序 (33)
- firebug 使用 (31)
- transactionmanager (30)
- characterencodingfilter (33)
- getmonth (34)
- commandtimeout (30)
- hibernate教程 (31)
- label换行 (33)
- curlpost (31)
- android studio 3 0 (34)
- android开发视频 (30)
- android应用开发 (31)