zoukankan      html  css  js  c++  java
  • react知识点汇总

    ①uncontrolComponent & controlComponent

              If your form is incredibly simple in terms of UI feedback, uncontrolled with refs is entirely fine. You don’t have to listen to what the various articles are saying is “bad.”

    featureuncontrolledcontrolled
    one-time value retrieval (e.g. on submit)
    validating on submit
    instant field validation
    conditionally disabling submit button
    enforcing input format
    several inputs for one piece of data
    dynamic inputs

        uncontrolComponent

          当不需要验证,或者提交的时候再验证等简单的功能的时候,input应该使用更为简单的  uncontrolComponent 用法的关键点为: ref获取该DOM的值

          <input ref=(ref)=>{this.input = ref} />
          //然后在需用用值的地通过this.input.value获取该值即可

        或者在onchange里实时检验,即使用户输入错误也让他输入,但是我们会实时给出错误的提示

            onChange={(e) => {
                               let v = e.target.value;
                               if (v) {
                                  if (/^[0-9]{1,30}$/.test(v)) {
                                     //成功
                                     this.showError();
                                  } else {
                                     this.showError("请输入正确的卡号");
                                  }
                               } else {
                                  this.showError("请输入卡号");
                               }
                               this.setState({
                                  inputValue: v
                               });
                            }}

        controlComponent

          需要立即验证,更改输入格式等则使用  controlComponent 

    -----------------------------------2017.12.25新增:----------------------------

    知识点一:按照功能 将此功能下的所有数据请求和管理,都存放在唯一一个根组件(容器组件)中;

          就像: OBT中的Pay.js,所有ajax都在这里,每当数据请求了,就改变自生的state,触发re-render,然后重新传递给子组件新的props;

          Pay.js就是“容器组件”,而其子组件,如:Panel,就是“展示组件”(不需要自己的state,数据都从父的“容器组件”中获取);

    知识点二:使用 PropTypes 和 getDefaultProps();

    1. 一定要写PropTypes,切莫为了省事而不写

    2. 如果一个Props不是requied,一定在getDefaultProps中设置它

      React.PropTypes主要用来验证组件接收到的props是否为正确的数据类型,如果不正确,console中就会出现对应的warning。出于性能方面的考虑,这个API只在开发环境下使用。

    /* 基本用法一 */
    Person.defaultProps = {
      name: 'Guest'
    };
    
    Person.propTypes = {
      name: React.PropTypes.string
    };



    /*
    基本用法二 */
    propTypes: {
        myArray: React.PropTypes.array,
        myBool: React.PropTypes.bool,
        myFunc: React.PropTypes.func,
        myNumber: React.PropTypes.number,
        myString: React.PropTypes.string,
         
         // You can chain any of the above with `isRequired` to make sure a warning
        // is shown if the prop isn't provided.
        requiredFunc: React.PropTypes.func.isRequired
    }
    

          当props是更为复杂的结构对象,

    如:

    {
      text: 'hello world',
      numbers: [5, 2, 7, 9],
    }

    则可使用进阶使用方法:shape() 和 arrayOf(),详细教程

     知识点三:Do not check existence of props at the root of a component. Components should not have two possible return types.



    -----------------------------------2017.12.26新增:----------------------------
    React的一些编程思想:
    state尽量抽取到公共父组件(容器组件)上,子组件(展示组件)不应该有自己的state,数据都是父组件专递过来的,子组件的更新依赖于父的state的更新引起的专递给自己的props的数据的改变,很多时候子组件自己需要自己控制自己更新,
    那怎么办呢?只能操作父组件上的state.
    由于组件只能更新它们自己的 state(状态),所以父组件应给相应的子组件传递setState回调方法。子通过此回调来改变父的state,从而实现自身的更新;
  • 相关阅读:
    20155335 俞昆 第十周作业
    课下加分项目 MYPWD 20155335 俞昆
    20155335 俞昆 实时系统 实验三
    20155335俞昆 2017-2018-1 《信息安全系统设计》第9周学习总结
    2017-2018-1 20155335 俞昆 《信息安全系统设计基础》第7周学习总结
    实验二 20155335 实验报告 固件程序设计
    2017-2018-1 20155319 《信息安全系统设计基础》第八周学习总结
    信息安全技术 实验三 数字证书应用
    第二次实验
    2017-2018-1 20155319 《信息安全系统设计基础》第七周学习总结
  • 原文地址:https://www.cnblogs.com/zhilingege/p/7856224.html
Copyright © 2011-2022 走看看