React functions inside render()

前端 未结 2 1635
醉梦人生
醉梦人生 2020-12-01 15:45

Is there a preference on where you put functions inside a react component. I am still learning react so just trying to figure out the best practices.

class          


        
2条回答
  •  -上瘾入骨i
    2020-12-01 16:29

    A function in the render method will be created each render which is a slight performance hit. It's also messy if you put them in the render, which is a much bigger reason, you shouldn't have to scroll through code in render to see the html output. Always put them on the class instead.

    For stateless components, it's probably best to keep functions outside of the main function and pass in props instead, otherwise the function will be created each render too. I haven't tested performance so I don't know if this is a micro-optimization but it's worth noting.

    Example:

    const MyStatelessComponent = ({randomProp}) => (
        render() {
            doSomething(randomProp);
    
            return 
    } ); doSomething = (randomProp) => { //Do something here }

提交回复
热议问题