2017-01-19 11 views
0

私は次のエラーレンダリング()

警告取得シンプルReduxのフォームを作成しようとしている:React.createElement:タイプはすべきではないヌル、未定義、ブール値を、または番号。これは文字列(DOM要素の場合)またはReactClass(複合コンポーネントの場合)でなければなりません。レンダリング方法がSearchProductsFormであることを確認してください。

これは私のフォームコンポーネントです。標準コンポーネントのみを使用しており、インポートステートメントはSimpleFormのサンプルからコピーされています。私は、次の行を削除した場合

import React, { Component, PropTypes } from 'react'; 
import { Field, reduxForm } from 'redux-form'; 
const { DOM: { input } } = React; 

@reduxForm({ 
    form: 'searchProducts', 
    fields: ['name'] 
}) 
export default 
class SearchProductsForm extends Component { 

    static propTypes = { 
    name: PropTypes.string, 
    handleSubmit: PropTypes.func.isRequired 
    }; 

    render() { 
    const { handleSubmit } = this.props; 
    return (
     <form onSubmit={handleSubmit}> 
      <div> 
      <label htmlFor="name">Name</label> 
       <Field name="name" component={input} type="text" placeholder="Last Name"/> 
      </div> 
      <button type="submit">Submit</button> 
     </form> 
    ); 
    } 
} 

コンポーネントが

<Field name="name" component={input} type="text" placeholder="Name"/> 

をレンダリングこれは私がReduxのフォーム3.0、私は6に更新したときにそれが動作を使用していた私の呼び出し側コンポーネント

import React, {Component, PropTypes} from 'react'; 
import Helmet from 'react-helmet'; 
import {connect} from 'react-redux'; 
import * as productActions from 'redux/modules/products'; 
import {isLoaded, load as loadProducts} from 'redux/modules/products'; 
import { asyncConnect } from 'redux-async-connect'; 
import { SearchProductsForm } from 'components'; 

@asyncConnect([{ 
    deferred: true, 
    promise: ({store: {dispatch, getState}}) => { 
    if (!isLoaded(getState())) { 
     return dispatch(loadProducts()); 
    } 
    } 
}]) 

@connect(
    state => ({ 
    products: state.products.data, 
    error: state.products.error, 
    loading: state.products.loading, 
    value: '' 
    }), 
    {...productActions }) 

export default class Products extends Component { 
    static propTypes = { 
    products: PropTypes.array, 
    error: PropTypes.string, 
    loading: PropTypes.bool, 
    load: PropTypes.func.isRequired, 


    }; 

    handleSubmit = (values) => { 
    console.log(values); 
    } 

    render() { 
    const {products} = this.props; 
    return (
     <div> 
     <Helmet title="Products"/> 
      <SearchProductsForm onSubmit={this.handleSubmit} /> 
      {products.map((product) => 
       <tr key={product._id}> 
       <td>{product._id}</td> 
       <td>{product._source.title}</td> 
       </tr>) 
      } 
      } 
     </div> 
    ); 
    } 
} 
+0

'input'変数を' component = {input} 'に渡しています。これは' Field'コンポーネントをカスタムコンポーネントでレンダリングすることを意味します「入力」と呼ばれる。デフォルトの入力をレンダリングしたいだけなら、 'component =" input "のように' 'input" 'を渡すだけです。さらに詳しい例は[http://redux-form.com/6.4.3/docs]を参照してください/api/Field.md/#usage](http://redux-form.com/6.4.3/docs/api/Field.md/#usage) – alpha

+0

返事ありがとうございます、残念ながら私は同じエラーが発生しますあなたの提案を試してください。私はAPIのドキュメントを見ましたが、それは私を助けませんでした。私はReactから{input}を使うhttp://redux-form.com/6.0.0-alpha.4/examples/simple/のSimple Formの例に従おうとしました –

答えて

0

です期待通りに

関連する問題