今回はreactデータの入力と同期についてお届けします。 以下は実際のケースです。
要件は以下の通りです
入力ボックスの入力内容のデータ長が0より大きく、プレビュー情報が表示される
カーソルが離れてプレビュー情報を閉じる
プレビュー情報は4桁ごとに特殊文字_が挿入され、入力内容は変わりません
長さは13桁までに制限されています
数字(0-9)のみ入力可能です
// Zinput.js import React, { Component } from 'react'; import './Zinput.css' // NOTE: 获取焦点事件 原生onFocus 即可 // NOTE: 离开焦点事件 原生onBlur即可 // NOTE: 输入框数据过滤 直接在change方法里进行过滤 // NOTE: 条件处理 通过不同条件返回不同节点做条件处理 class Zinput extends Component { constructor(props) { super(props); this.state = { value: '', showBig: false, }; this.handleChange = this.handleChange.bind(this); this.inputOnFocus = this.inputOnFocus.bind(this); this.inputOnBlur = this.inputOnBlur.bind(this); } inputOnFocus() { if (this.state.value.length > 0) { this.setState({ showBig: true }) } } inputOnBlur() { this.setState({ showBig: false }) if(this.props.chanegNumber){ this.props.chanegNumber(this.state.value) } } handleChange(event) { let val = event.target.value.substr(0, 13) .replace(/[^\d]/g, '') event.target.value = val this.setState({ value: val, showBig: true, }); } /** * 根据字符串没隔len位插入一个下滑杠,返回处理后的字符串 * @method getStr * @author 朱阳星 * @datetime 2018-04-02T09:57:58+080 * @email zhuyangxing@foxmail.com * @param {String} str 待处理字符串 * @param {Number} len 每隔位数插入下滑杠 * @return {String} 处理后的字符串 */ getStr(str, len) { let lenth = str.length let len1 = len - 1 let newStr = '' for (var i = 0; i < lenth; i++) { if (i % len === len1 && i > 0) { newStr += str.charAt(i) + '_' } else { newStr += str.charAt(i) } } if (newStr.length % (len + 1) === 0) { // 解决最后一位为补充项问题 newStr = newStr.substr(0, newStr.length - 1) } return newStr } render() { // NOTE return 需要用圆括号包住并处理 // NOTE 条件语句里没有节点也要用空字符串进行处理 否则sonalint会报错,页面也会报错 const showBig = this.state.showBig ? ( <p className="big-show">{ this.getStr(this.state.value,4) }</p> ) : '' return ( <p className="zInput"> <input className="input" type = "text" onFocus={ this.inputOnFocus } onBlur={ this.inputOnBlur } value={ this.state.value } onChange={ this.handleChange }> </input> {showBig} </p> ) } } export default Zinput; // Don't forget to use export default!
関数が実装されると、それは特定のノードの子コンポーネントとして使用される必要があります。親コンポーネントの呼び出しメソッドは 2 つあります
1。サブコンポーネントの葉に焦点を当て、親コンポーネントから渡されたメソッドを呼び出して、親コンポーネントの状態値を変更します
<!-- Zinput.css --> .zInput{ position: absolute; top:80px; left:40px; } .input { position: absolute; top: 0; left: 0; } .big-show { position: relative; top: -40px; font-size: 36px; line-height: 40px; background-color: red; }
この記事の事例を読んだことがあるかと思いますが、メソッドをマスターした後は、関連する他の記事にも注目してください。 php 中国語 Web サイトでさらにエキサイティングなコンテンツをお楽しみください!
推奨読書:
プロジェクトで vue+mint-ui を使用する方法 vue を使用して単一ページ アプリケーションのフロントエンド ルーティングを作成する方法以上が入力データに反応して同期するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。