AutoWidthInput

Posted laneyfu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AutoWidthInput相关的知识,希望对你有一定的参考价值。

import React from ‘react‘;
import PropTypes from ‘prop-types‘;

class AutoWidthInput extends React.Component {

  static propTypes = {
    value: PropTypes.string,
    placeholder: PropTypes.string,
    minWidth: PropTypes.number,
    onChange: PropTypes.func
  }

  static defaultProps = {
    minWidth: 28,
    onChange: () => { }
  }

  constructor(props) {
    super(props);
    this.state = {
      inputWidth: props.minWidth
    };
  }

  componentDidMount() {
    this.updateInputWidth();
  }


  componentDidUpdate() {
    this.updateInputWidth();
  }

  updateInputWidth = () => {
    let width = Math.max(this.sizer.scrollWidth, this.placeholderSizer.scrollWidth) + 2;
    width = Math.max(width, this.props.minWidth);
    const { inputWidth } = this.state;
    if (inputWidth !== width) {
      this.setState({ inputWidth: width });
    }
  }
  handleChange = (e) => {
    this.setState({ value: e.target.value });
    this.props.onChange(e);
  }
  render() {
    const { inputWidth } = this.state;
    const { value, placeholder } = this.props;
    return (
      <div style={{ display: ‘inline-block‘ }}>
        <input
          style={{ width: inputWidth }}
          type="text"
          value={value}
          onChange={this.handleChange}
          placeholder={placeholder}
        />
        <div ref={(div) => { this.sizer = div; }} style={{ position: ‘absolute‘, top: 0, left: 0, visibility: ‘hidden‘, height: 0, overflow: ‘scroll‘, whiteSpace: ‘pre‘ }}>
          {value}
        </div>
        <div ref={(div) => { this.placeholderSizer = div; }} style={{ position: ‘absolute‘, top: 0, left: 0, visibility: ‘hidden‘, height: 0, overflow: ‘scroll‘, whiteSpace: ‘pre‘ }}>
          {placeholder}
        </div>
      </div>
    );
  }
}

export default AutoWidthInput;

  

以上是关于AutoWidthInput的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段——CSS选择器

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

片段和活动之间的核心区别是啥?哪些代码可以写成片段?

VSCode自定义代码片段——.vue文件的模板

VSCode自定义代码片段6——CSS选择器

VSCode自定义代码片段——声明函数