zoukankan      html  css  js  c++  java
  • React准备

    React 准备

    初始化项目

    1. 安装create-react-app

      打开终端执行: npm i create-react-app -g

    2. 执行create-react-app AwesomeProject

    3. 执行yarn start

    在vscode中添加chrome调试工具

    1. 在vscode的扩展中搜索并安装Debugger for Chrome

    2. 在调试窗口(ctrl+shift+d)配置, 选择"添加配置"

    3. 写配置文件(launch.json)

      eg:

      {
        "type": "chrome",
        "request": "launch",
        "name": "Chrome",
        "url": "http://localhost:3000",
        "webRoot": "${workspaceRoot}/src",
        "userDataDir": "${workspaceRoot}/.vscode/chrome",
        "sourceMapPathOverrides": {
          "webpack:///src/*": "${webRoot}/*"
        }
      }
      
    4. 在调试窗口点击,开始调试.(需要先在终端执行yarn start)

    知识储备

    1. ES6语法

      • 导入其他组件/对象/方法import与暴露组件/对象/方法export

        常见用法:

        1. MyText.js中暴露一个组件
          import React, { Component } from 'react'
          
          export default class MyText extends Component {
          
          }
          
        2. MyText.js同级目录下的一个文件中导入该组件
          //说明: 
          //路径: './'表示同级目录下的文件
          //省略后缀: 后缀为.js的可以省略不写
          import MyText from './MyText' 
          
        3. util.js工具方法中暴露一个对象
          //形式1
          export function func1() {
            
          }
          
          export function func2() {
            
          }
          
          //形式2 效果等同于 形式1
          
          function func1() {
            
          }
          
          function func2() {
            
          }
          
          export default {
            func1,
            func2
          }
          
        4. util.js中导入对象或指定方法
          
          //导入整个对象
          import util from './../util'
          
          util.func1();
          util.func2();
          
          //导入指定方法
          import {func1} from './../util'
          
          func1();
          
      • 箭头函数(参数) => {函数体}

        几个特性:

        1. this
        2. arguments
        3. 不可作为构造函数
      • Promise

        主要用于美化异步操作代码, 使其能够有同步代码的阅读体验, 避免出现地狱回调.

        有三种状态:

        1. padding, 等待结果
        2. reject, 拒绝/错误
        3. resolve, 成功
        

        eg:

        let func1 = () => {
          let p = new Promise((resolve, reject) => {
            setTimeout(() => {
              if (true) {
                resolve('success');
              } else {
                reject();
              }
            }, 500);
          });
          return p;
        };
        let func2 = () => {
          let p = new Promise((resolve, reject) => {
            setTimeout(() => {
              if (false) {
                resolve();
              } else {
                reject('error');
              }
            }, 500);
          });
          return p;
        };
        
        func
        .then((data) => {
        
          //500ms后执行
          console.log(data);
          return func2();
        })
        .then(() => {
        
          //未执行
          console.log('1');
        }, (errorData) => {
          console.log(errorData);
        })
        .catch((errMsg) => {
        
          //统一处理error
          console.error(errMsg);
        });
        
        
    2. JSX语法

      1. 内部使用插值表达式, (关于表达式和语句的区别)

        eg:

        function greeting(text) {
          return <h1>{ text }</h1>
        }
        
        //单括号内部使用js表达式,例如:
        /*
        { number + 1 }
        { ok ? 'YES' : 'NO' }
        { message.split('').reverse().join('') }
        */
        
      2. 它本身也是表达式的一种, 和JavaScript语句一起使用即可.

      3. 特殊的属性写法

        eg:

        1. class => className
        const el1 = (
          <div className="yourName">
            <h1>hello</h1>
            <b>world</b>
          </div>
        );
        
        1. src="example.jpg" => src={yourPath}, typeof yourPath is String
        const yourPath = 'example.jpg';
        const el2 = {
          <img src={yourPath} />
        };
        
        //or
        const el3 = {
          <img src="example.jpg" /> //传统html中属性的写法
        };
        
        //error
        const el4 = {
          <img src="yourPath" />  //路径为yourPath, 而不是example.jpg
        };
        
      4. 注意

        在JavaScript语句中直接套用html标签或者自定义组件等同于使用React.createElement()方法, 当然这需要使用babel对其进行编译.

    3. DOM elementReact element

      1. DOM element为传统的html标签.

      2. React element是一个简单的对象(原文: a plain Object), 由React.createElement()方法得到, 并且所有的React element构成React DOM.

        eg:

        const element = React.createElement(
          'h1',
          {className: 'greeting'},
          'Hello, world!'
        );
        
      3. 使用ReactDOM.render()方法可以在DOM中注入React DOM.
        纯React的项目一般来说只需要一个root DOM.而在一个已有的项目中, 你可以提供多个dom节点, 作为注入React DOM的入口.

    扩展

    create-react-app默认支持的方法有:

    • "..."对象展开符

      eg:

      let obj1 = {
        name: 'zgatry',
        address: '杭州',
        age: 18
      };
      let obj2 = {
        ...obj1,
        age: 23
      };
      console.log(obj2);
      /*
      {
        name: 'zgatry',
        address: '杭州',
        age: 23
      }
      */
      
    • Object.assign()方法

  • 相关阅读:
    线程同步的三种方式(Mutex,Event,Critical Section) 沧海
    VC++多线程下内存操作的优化 沧海
    C++内存对象大会战 沧海
    技术关注:搜索引擎经验 沧海
    jira 3.13.5版 安装 配置 用户权限控制 拂晓风起
    C++ int string 转换 拂晓风起
    C++调用C链接库会出现的问题 拂晓风起
    Windows Server 2003 IIS Service Unavailable 问题解决 拂晓风起
    研究 学术 开发 的好用工具(不包括常见的) 拂晓风起
    SGMarks 问世 (Firefox扩展Gmarks的扩展版) 纯属学习 拂晓风起
  • 原文地址:https://www.cnblogs.com/foxNike/p/7161595.html
Copyright © 2011-2022 走看看