defaultValue change does not re-render input

前端 未结 2 865
栀梦
栀梦 2021-01-17 20:25

I have no idea why this is not working

Demo

I have the following es6 code

const {createFactory, createClass, DOM: { label, input, button }} =         


        
相关标签:
2条回答
  • 2021-01-17 21:14

    You only specify its default value, but don't tell it to change its value with a change to props.

    ,input({value: this.props.name})
    

    Will change the value when this.props.name changes.

    http://output.jsbin.com/melitecimo

    0 讨论(0)
  • 2021-01-17 21:18

    I found what seems to be a pretty good solution to this: Use the key prop to force rendering of an entirely new input.

    In my particular case, I don't need the input to be controlled with its own onChange prop, as the form surrounding it ultimately controls the state within some store which populates the defaultValue. But the store's state might be asynchronously initialized/updated, and in which case the defaultValue should be updated. So here is a condensed version of my particular case:

    import React, { PropTypes } from 'react';
    import { Form } from 'provide-page';
    
    const GatherContact = ({
      classes,
      onSubmit,
      movingContactName,
      movingContactEmail,
      movingContactPhone,
      userName,
      userEmail,
      userPhone
    }) => (
      <Form onSubmit={onSubmit}>
        <div className={classes.GatherContact}>
          <h2 className={classes.GatherHeading}>
            How can we contact you?
          </h2>
    
          <input
            type="text"
            className={classes.GatherContactInput}
            placeholder="Name"
            name="movingContactName"
            key={`movingContactName:${movingContactName || userName}`}
            defaultValue={movingContactName || userName}
            required={true}
          />
    
          <input
            type="email"
            className={classes.GatherContactInput}
            placeholder="Email"
            name="movingContactEmail"
            key={`movingContactEmail:${movingContactEmail || userEmail}`}
            defaultValue={movingContactEmail || userEmail}
            required={true}
          />
    
          <input
            type="tel"
            className={classes.GatherContactInput}
            placeholder="Phone"
            name="movingContactPhone"
            key={`movingContactPhone:${movingContactPhone || userPhone}`}
            defaultValue={movingContactPhone || userPhone}
            required={true}
          />
    
          {userName
            ? undefined
            : (
              <input
                type="password"
                className={classes.GatherContactInput}
                placeholder="Password"
                name="userPassword"
                required={true}
                autoComplete="new-password"
              />
            )
          }
        </div>
      </Form>
    );
    
    GatherContact.propTypes = {
      classes: PropTypes.object.isRequired,
      onSubmit: PropTypes.func.isRequired,
      movingContactName: PropTypes.string.isRequired,
      movingContactEmail: PropTypes.string.isRequired,
      movingContactPhone: PropTypes.string.isRequired,
      userName: PropTypes.string.isRequired,
      userEmail: PropTypes.string.isRequired,
      userPhone: PropTypes.string.isRequired
    };
    
    export default GatherContact;
    
    0 讨论(0)
提交回复
热议问题