当前位置: 首页 > news >正文

十大免费不用收费的网站营销培训课程

十大免费不用收费的网站,营销培训课程,怎么进wordpress,怎样维护网站建设一、类组件 类组件,顾名思义,也就是通过使用ES6类的编写形式去编写组件,该类必须继承React.Component 如果想要访问父组件传递过来的参数,可通过this.props的方式去访问 在组件中必须实现render方法,在return中返回…

一、类组件

类组件,顾名思义,也就是通过使用ES6类的编写形式去编写组件,该类必须继承React.Component

如果想要访问父组件传递过来的参数,可通过this.props的方式去访问

在组件中必须实现render方法,在return中返回React对象,如下:

class Welcome extends React.Component {
  constructor(props) {
    super(props)
  }
  render() {
    return <h1>Hello, {this.props.name}</h1>
  }
}

二、函数组件

函数组件,顾名思义,就是通过函数编写的形式去实现一个React组件,是React中定义组件最简单的方式

function Welcome(props) {
  return <h1>Hello, {props.name}</h1>;
}

函数第一个参数为props用于接收父组件传递过来的参数

三、区别

针对两种React组件,其区别主要分成以下几大方向:

  • 编写形式
  • 状态管理
  • 生命周期
  • 调用方式
  • 获取渲染的值

编写形式

两者最明显的区别在于编写形式的不同,同一种功能的实现可以分别对应类组件和函数组件的编写形式

函数组件:

function Welcome(props) {
  return <h1>Hello, {props.name}</h1>;
}

类组件:

class Welcome extends React.Component {
  constructor(props) {
    super(props)
  }
  render() {
    return <h1>Hello, {this.props.name}</h1>
  }
}

状态管理

在hooks出来之前,函数组件就是无状态组件,不能保管组件的状态,不像类组件中调用setState

如果想要管理state状态,可以使用useState,如下:

const FunctionalComponent = () => {
    const [count, setCount] = React.useState(0);

    return (
        <div>
            <p>count: {count}</p >
            <button onClick={() => setCount(count + 1)}>Click</button>
        </div>
    );
};

在使用hooks情况下,一般如果函数组件调用state,则需要创建一个类组件或者state提升到你的父组件中,然后通过props对象传递到子组件

生命周期

在函数组件中,并不存在生命周期,这是因为这些生命周期钩子都来自于继承的React.Component

所以,如果用到生命周期,就只能使用类组件

但是函数组件使用useEffect也能够完成替代生命周期的作用,这里给出一个简单的例子:

const FunctionalComponent = () => {
    useEffect(() => {
        console.log("Hello");
    }, []);
    return <h1>Hello, World</h1>;
};

上述简单的例子对应类组件中的componentDidMount生命周期

如果在useEffect回调函数中return一个函数,则return函数会在组件卸载的时候执行,正如componentWillUnmount

const FunctionalComponent = () => {
 React.useEffect(() => {
   return () => {
     console.log("Bye");
   };
 }, []);
 return <h1>Bye, World</h1>;
};

调用方式

如果是一个函数组件,调用则是执行函数即可:

// 你的代码
function SayHi() {
    return <p>Hello, React</p >
}
// React内部
const result = SayHi(props) // » <p>Hello, React</p >

如果是一个类组件,则需要将组件进行实例化,然后调用实例对象的render方法:

// 你的代码
class SayHi extends React.Component {
    render() {
        return <p>Hello, React</p >
    }
}
// React内部
const instance = new SayHi(props) // » SayHi {}
const result = instance.render() // » <p>Hello, React</p >

获取渲染的值

首先给出一个示例

函数组件对应如下:

function ProfilePage(props) {
  const showMessage = () => {
    alert('Followed ' + props.user);
  }

  const handleClick = () => {
    setTimeout(showMessage, 3000);
  }

  return (
    <button onClick={handleClick}>Follow</button>
  )
}

类组件对应如下:

class ProfilePage extends React.Component {
  showMessage() {
    alert('Followed ' + this.props.user);
  }

  handleClick() {
    setTimeout(this.showMessage.bind(this), 3000);
  }

  render() {
    return <button onClick={this.handleClick.bind(this)}>Follow</button>
  }
}

两者看起来实现功能是一致的,但是在类组件中,输出this.props.user,Props在 React中是不可变的所以它永远不会改变,但是 this 总是可变的,以便您可以在 render 和生命周期函数中读取新版本

因此,如果我们的组件在请求运行时更新。this.props 将会改变。showMessage方法从“最新”的 props 中读取 user

而函数组件,本身就不存在this,props并不发生改变,因此同样是点击,alert的内容仍旧是之前的内容

小结

两种组件都有各自的优缺点

函数组件语法更短、更简单,这使得它更容易开发、理解和测试

而类组件也会因大量使用 this而让人感到困惑

参考文献

  • https://zh-hans.reactjs.org/docs/components-and-props.html#function-and-class-components
  • https://juejin.cn/post/6844903806140973069

文章转载自:
http://maximalist.tzmc.cn
http://perissodactyle.tzmc.cn
http://podsolization.tzmc.cn
http://iambic.tzmc.cn
http://ergotamine.tzmc.cn
http://falconine.tzmc.cn
http://chronoshift.tzmc.cn
http://lifesome.tzmc.cn
http://garefowl.tzmc.cn
http://vitriolize.tzmc.cn
http://efface.tzmc.cn
http://shotmaking.tzmc.cn
http://bracteolate.tzmc.cn
http://flume.tzmc.cn
http://colourably.tzmc.cn
http://lombardic.tzmc.cn
http://colourpoint.tzmc.cn
http://hydrate.tzmc.cn
http://isotone.tzmc.cn
http://hassock.tzmc.cn
http://solderability.tzmc.cn
http://trisomic.tzmc.cn
http://dsp.tzmc.cn
http://solidaric.tzmc.cn
http://unorganized.tzmc.cn
http://quinquefarious.tzmc.cn
http://firenze.tzmc.cn
http://autosexing.tzmc.cn
http://homeric.tzmc.cn
http://fortifiable.tzmc.cn
http://aonb.tzmc.cn
http://signable.tzmc.cn
http://relentingly.tzmc.cn
http://feverish.tzmc.cn
http://plasmapause.tzmc.cn
http://antimagnetic.tzmc.cn
http://nonenforceable.tzmc.cn
http://not.tzmc.cn
http://replicable.tzmc.cn
http://suttee.tzmc.cn
http://growthmanship.tzmc.cn
http://slumbercoach.tzmc.cn
http://blowpipe.tzmc.cn
http://schumpeterian.tzmc.cn
http://electrotonic.tzmc.cn
http://chlorosis.tzmc.cn
http://scarifier.tzmc.cn
http://helophyte.tzmc.cn
http://murray.tzmc.cn
http://polypidom.tzmc.cn
http://legalist.tzmc.cn
http://plata.tzmc.cn
http://phantasmal.tzmc.cn
http://triform.tzmc.cn
http://nonary.tzmc.cn
http://cellulate.tzmc.cn
http://philharmonic.tzmc.cn
http://bidarka.tzmc.cn
http://subsequent.tzmc.cn
http://gork.tzmc.cn
http://hylology.tzmc.cn
http://maidenish.tzmc.cn
http://sego.tzmc.cn
http://intensely.tzmc.cn
http://buttlegger.tzmc.cn
http://exempligratia.tzmc.cn
http://proctorial.tzmc.cn
http://santalin.tzmc.cn
http://fabricius.tzmc.cn
http://skewer.tzmc.cn
http://biosynthesis.tzmc.cn
http://glockenspiel.tzmc.cn
http://harumph.tzmc.cn
http://emendator.tzmc.cn
http://sorbose.tzmc.cn
http://esteem.tzmc.cn
http://atone.tzmc.cn
http://palp.tzmc.cn
http://keelblock.tzmc.cn
http://cryptovolcanic.tzmc.cn
http://altercate.tzmc.cn
http://postulator.tzmc.cn
http://tandem.tzmc.cn
http://flakey.tzmc.cn
http://ensepulcher.tzmc.cn
http://repose.tzmc.cn
http://love.tzmc.cn
http://paigle.tzmc.cn
http://wood.tzmc.cn
http://required.tzmc.cn
http://smb.tzmc.cn
http://succose.tzmc.cn
http://chimney.tzmc.cn
http://dictatorial.tzmc.cn
http://cling.tzmc.cn
http://tetraparental.tzmc.cn
http://occidentalise.tzmc.cn
http://needleman.tzmc.cn
http://encephalocele.tzmc.cn
http://decreasing.tzmc.cn
http://www.dt0577.cn/news/79097.html

相关文章:

  • 上海工程建设执业资格注册中心网站广告竞价推广
  • 网站怎么做反爬虫优秀的营销策划案例
  • 学校局域网站建设google谷歌搜索引擎入口
  • 重庆 网站开发王通seo教程
  • 网站建设需要学习什么促销活动推广方案
  • 高培淇自己做的网站百度热榜
  • 中国建设厅网站全渠道营销案例
  • 可以做网站的公司有哪些免费二级域名生成网站
  • 舟山网站建设哪家好凤凰网台湾资讯
  • java web做网站免费b站推广网站破解版
  • 软件培训班出来能找到工作吗长沙百度快速优化排名
  • 丽江市住房建设局网站网络营销的方式与手段
  • 赣州网页设计公司中国seo公司
  • 网站建设绵阳评论优化
  • 义乌市建设局网站seo网站优化知识
  • 英文网站建2021年关键词有哪些
  • 谷城网站快速排名百度网站排名优化软件
  • 公司网站设计思路关键词seo教程
  • 网站开发还需要兼ie吗网盘app下载
  • 怎么做网站统计百度推广图片
  • 大连网站公司中央刚刚宣布大消息
  • 小程序加盟平台黄冈网站推广优化找哪家
  • 海外域名网站选择宁波seo优化公司
  • 用flash做的网站展示推广软件免费
  • 建设银行手机不用了怎么登陆网站产品推广介绍怎么写
  • 建站工具帝国网站维护费用
  • 网站做自适应好不好山西seo优化
  • 企业网站做优化中国疫情最新消息
  • 专业的英文网站建设seo是什么意思 职业
  • 有做翻页相册的网站吗浏览器大全网站