ReactJS中的自定义组件

Posted xsd1

tags:

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

可控自定义组件:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <script src="js/react.js"></script>
        <script src="js/react-dom.js"></script>
        <script src="js/browser.min.js"></script>
    </head>
    <body>
        <script type="text/babel">
            var Radio=React.createClass({
                getInitialState:function(){
                    return {
                        value:this.props.defaultValue
                    };
                },
                handleChange:function(event){
                    if(this.props.onChange){
                        this.props.onChange(event);
                    }
                    this.setState({
                        value:event.target.value
                    });
                },
                render:function(){
                    var children=[];
                    var value=this.props.value||this.state.value;
                    React.Children.forEach(this.props.children,function(child,i){
                        var label=<label key={i}>
                            <input type="radio" name={this.props.name} value={child.props.value} checked={child.props.value==value} onChange={this.handleChange}/>
                            {child.props.children}
                            <br/>
                    </label>;
                    children.push(label);
                    }.bind(this));
                    return <span>{children}</span>;
                }
            });
            var MyForm=React.createClass({
                getInitialState:function(){
                    return ({my_radio:"B"});
                },

                handleChange:function(event){
                    this.setState({
                        my_radio:event.target.value
                    });
                },
                submitHandler:function(event){
                    event.preventDefault();
                    alert(this.state.my_radio);
                },
                render:function(){
                    return (
                        <form onSubmit={this.submitHandler}>
                        <Radio value={this.state.my_radio} name="my_radio" onChange={this.handleChange}>
                            <option value="A">First option</option>
                            <option value="B">Second option</option>
                            <option value="C">Third option</option>
                        </Radio>
                        <button type="submit">Speak</button>
                        </form>
                    )
                }
            });

            ReactDOM.render(<MyForm></MyForm>,document.body);
        </script>
    </body>
</html>

不可控的自定义组件:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <script src="js/react.js"></script>
        <script src="js/react-dom.js"></script>
        <script src="js/browser.min.js"></script>
    </head>
    <body>
        <script type="text/babel">
            var Radio=React.createClass({
                getInitialState:function(){
                    return {
                        value:this.props.defaultValue
                    };
                },
                handleChange:function(event){
                    if(this.props.onChange){
                        this.props.onChange(event);
                    }
                    this.setState({
                        value:event.target.value
                    });
                },
                render:function(){
                    var children=[];
                    var value=this.props.value||this.state.value;
                    React.Children.forEach(this.props.children,function(child,i){
                        var label=<label>
                            <input type="radio" name={this.props.name} value={child.props.value} checked={child.props.value==value} onChange={this.handleChange}/>
                            {child.props.children}
                            <br/>
                    </label>;
                    children[‘label‘+i]=label;
                    }.bind(this));
                    return <span>{children}</span>;
                }
            });
            var MyForm=React.createClass({
                handleSubmit:function(event){
                    event.preventDefault();
                    alert(this.refs.radio.state.value);
                },
                render:function(){
                    return (
                        <form onSubmit={this.handleSubmit}>
                        <Radio ref="radio" name="my_radio" defaultValue="B">
                            <p value="A">First</p>
                            <option value="B">Second option</option>
                            <option value="C">Third option</option>
                        </Radio>
                        <button type="submit">Speak</button>
                        </form>
                    )
                }
            });

            ReactDOM.render(<MyForm></MyForm>,document.body);
        </script>
    </body>
</html>
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <script src="js/react.js"></script>
        <script src="js/react-dom.js"></script>
        <script src="js/browser.min.js"></script>
    </head>
    <body>
        <script type="text/babel">
            var Radio=React.createClass({
                getInitialState:function(){
                    return {
                        value:this.props.defaultValue
                    };
                },
                handleChange:function(event){
                    if(this.props.onChange){
                        this.props.onChange(event);
                    }
                    this.setState({
                        value:event.target.value
                    });
                },
                render:function(){
                    var children=[];
                    var value=this.props.value||this.state.value;
                    React.Children.forEach(this.props.children,function(child,i){
                        var label=<label>
                            <input type="radio" name={this.props.name} value={child.props.value} checked={child.props.value==value} onChange={this.handleChange}/>
                            {child.props.children}
                            <br/>
                    </label>;
                    children[label+i]=label;
                    }.bind(this));
                    return <span>{children}</span>;
                }
            });
            var MyForm=React.createClass({
                handleSubmit:function(event){
                    event.preventDefault();
                    alert(this.refs.radio.state.value);
                },
                render:function(){
                    return (
                        <form onSubmit={this.handleSubmit}>
                        <Radio ref="radio" name="my_radio" defaultValue="B">
                            <p value="A">First</p>
                            <option value="B">Second option</option>
                            <option value="C">Third option</option>
                        </Radio>
                        <button type="submit">Speak</button>
                        </form>
                    )
                }
            });

            ReactDOM.render(<MyForm></MyForm>,document.body);
        </script>
    </body>
</html>

本人刚建立一个前端学习交流群,群内有很多干货适合前期和中期需要解决的问题,欢迎给位进群一起探讨互相帮助907694362祝各位在前端的道路上一帆风顺!!

 

以上是关于ReactJS中的自定义组件的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Reactjs 的组件状态下使用 OOP?

ReactJS 中的样式化组件自定义 CSS

react JS中的自定义音频播放器-音量控制

具有获取 json 值的片段中的自定义适配器

在 ReactJS 的组件构造方法中获取上下文值的任何方法

片段中的自定义列表适配器