• 学习React框架-总结


    参加了华为云的大前端全栈成长计划学习课程,每次学习一个新的知识后都要总结一下学习的过程,这样有助于自己的知识整理,内容回顾,加深记忆。从前端基础Html,CSS,JavaScript的学习,移动端H5开发的学习,到前端框架NodeJs、Vue的学习,现在已经到了最后一个阶段了。既然想在技术这个行业成长,那就要时刻保持对新技术和流行技术的敏感性,而React,Vue和Angular已占领了前端的大部分市场,因此我们也要学习和了解这些主流框架方面的知识。

    这篇文章我们主要来总结一下React的学习过程,React是一个声明式,高效且灵活的用于构建用户界面的JavaScript库,主要用来构建UI,是起源于Facebook的一个内部项目。React的生态完善,社区活跃,官方文档也比较详细,学起来也比较容易。可以参考官方文档:React 

    创建项目

    1.静态页面创建

    页面直接引入React,ReactDOM的js文件:react.jsreact-dom.js

    页面CDN引入:

    React:https://cdn.bootcdn.net/ajax/libs/react/16.14.0/umd/react.development.js

    ReactDOM:https://cdn.bootcdn.net/ajax/libs/react-dom/16.14.0/cjs/react-dom.development.js

    2.通过脚手架创建

    全局安装:npm install -g create-react-app

    创建项目:create-react-app react-demo

    有了vue的基础,我们直接通过脚手架创建项目,开始我们React的学习旅程。

    目录结构

    react-demo
    --node_modules   // 项目依赖包
    --public   // 公共资源文件,如:图片,json文件等
    --src        // 项目页面组件,样式,脚本文件,路由等
    --package.json  // 项目webpack配置和包管理文件
    --README.md  // 项目说明文件

    运行:npm run start

    项目模板的初始页面就可以访问了:http://localhost:3000/

    渲染组件

    文件 src/index.js

    可以看到 ReactDOM.render() ,渲染组件(App),把模板转换成html语言并插入到指定的节点。

    导入 react(import React from 'react'),react-dom(import ReactDOM from 'react-dom')

    文件src/App.js

    这里使用了JSX语法写html页面,遇到html标签(例如:<>)就用html解析,遇到代码块(例如:{ })就用javascript规则解析。

    可以尝试修改里面的内容,预览效果。

    数据绑定

    React里面没有像Vue里面那么简单的数据绑定功能,这里需要我们自己去完成表单控件的数据绑定的功能。

    使用状态 state 存储输入控件的值,使用 onChange 的回调函数,通过 this.setState 修改 state 里面的值,每次修改完会自动调用 this.render 方法,再次渲染组件。这样就可以实现输入框的数据绑定。

    import React, { Component } from 'react'
    
    export default class AddUser extends Component {
        // 定义状态
        state = {
            userName: "",
            userAge: ""
        }
        // 定义表单控件输入框事件
        handleChange = (event)=>{
            // 获取控件名称 name
            const name = event.target.name;
            this.setState({
                [name]: event.target.value   // 获取控件的值
            });
        }
        // 定义按钮事件
        handleAddUser = () => {
            console.log("用户名和年龄:", this.state)
        }
        render() {
            return (
                <div>
                    <div><input name="userName" value={this.state.userName} onChange={this.handleChange} placeholder="请输入用户名" /></div>
                    <div><input name="userAge" value={this.state.userAge} onChange={this.handleChange} placeholder="请输入年龄" /></div>
                    <div><input onClick={this.handleAddUser} value="添加"/></div>
                </div>
            )
        }
    }

    生命周期

    React中组件的生命周期分为三个状态,Mounting是已经插入真实DOM,Updating是正在被重新渲染,Unmounting是已移出真实DOM。每个状态都有两种处理函数,will函数是进入状态之前,did函数是进入状态之后,共有五个函数如下:

    componentWillMount()

    componentDidMount(),一般会在这个里面请求数据

    componentWillUpdate(object nextProps,object nextState)

    componentWillUpdate(object prevState, object prevState)

    componentWillUnMount(),这里面一般会清除定时器,清空对象

    唯一ID生成器

    nanoid是一个非常小巧,安全友好的JavaScript唯一ID生成器,比 uuid 更可靠和易用,源码地址:https://github.com/ai/nanoid

    在模拟添加数据的时候,一般都会需要一个唯一ID值,那么我们就使用 nanoid 来生成这个ID值。

    安装:npm install nanoid --save

    导入:import { nanoid } from 'nanoid'

    使用:const id = nanoid();

    其它使用方法参考文档:https://www.npmjs.com/package/nanoid

    Props

    Props 是只读的,不能修改自身的props,父子组件传值就要通过 props 来完成。

    Props 验证使用 propTypes,它可以保证我们的应用组件被正确使用。参考:https://www.npmjs.com/package/prop-types

    安装:npm install prop-types --save

    发布订阅(pubsub-js)

    React的父子组件之间可以通过props传递值,如果组件和组件之间需要传值的话要借助它们的父组件进行传值,这样父组件需要定义state和写好多回调函数。如果想在任意组件传递数据可以使用 pubsub-js 来完成。

    安装:npm install pubsub-js --save

    导入:import PubSub from 'pubsub-js'

    使用:

    PubSub.publish('name', param)   // 发布订阅,name: 发布的消息名,param:提供给订阅者的参数

    PubSub.subscribe('name', func)  // 订阅消息,name: 发布的消息名,func:事件的监听函数

    var func = function(msg, data) {

        console.log(msg,data);

    }

    PubSub.unsubscribe('name')  // 取消订阅

    有关 pubsub-js 的其它用法,可以参考文档:https://www.npmjs.com/package/pubsub-js

    调试工具

    谷歌浏览器安装插件:react developer tools,打开开发者工具,调试窗口如下图:

    温馨提示

    文章内容如果写的存在问题欢迎留言指出,让我们共同交流,共同探讨,共同进步~~~

    文章如果对你有帮助,动动你的小手点个赞,鼓励一下,给我前行的动力。

    作者:zeke     
              出处:http://zhf.cnblogs.com/
              本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 

  • 相关阅读:
    xss学习笔记
    【转】Python中的正则表达式(re)
    数据隐藏技术揭秘笔记
    几道排列组合题的总结
    Notepad++来比较文件
    快捷键总结
    进制转换
    leetcode刷题(三)
    leetcode刷题(二)
    leetcode刷题(一)
  • 原文地址:https://www.cnblogs.com/ZHF/p/15474860.html
Copyright © 2020-2023  润新知