5分钟入门react教程(提供源码)

简单易懂的react 入门教程

  • React :是一个用于构建用户界面的 JavaScript 库
  • JSX: React 中建议使用jsx语法,jsx最终会被转为普通 JavaScript 函数
  • TypeScript :是JavaScript 的一个类型超集,TypeScript 可以在构建时发现 bug 和错误,这样程序运行时就可以避免此类错误,.ts 是默认的文件扩展名,而 .tsx 是一个用于包含 JSX 代码的特殊扩展名
  • Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。

GitHub地址: https://github.com/itainf/demo-react
体验地址:http://wojson.com/demo/demo-react/hello.html

一. 安装nodejs

nodejs 是开发JavaScript 程序的运行环境,必须先安装
下载地址:Node.js

二. 创建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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值