react native Hooks 初体验

从官方文档中,我们可以得到以下的一些特性:

  • 完全可选的。 你无需重写任何已有代码就可以在一些组件中尝试 Hook。但是如果你不想,你不必现在就去学习或使用 Hook。
  • 100% 向后兼容的。 Hook 不包含任何破坏性改动。
  • 现在可用。 Hook 已发布于 v16.8.0。
  • 不能再 class 里面使用

没有计划从 React 中移除 class。 你可以在本页底部的章节读到更多关于 Hook 的渐进策略。

Hook 不会影响你对 React 概念的理解。 恰恰相反,Hook 为已知的 React 概念提供了更直接的 API:props, state,context,refs 以及生命周期。

使用

import React, { useEffect } from 'react'
export default function Toast() {
const [count, setCount] = useState(0);
  useEffect(() => {
	 setCount(count + 1)
    return () => {
      console.log('useEffect');
      
    }
  })

  return <ToastModal count={count} />
}

调用

Toast()

报错

Hooks can only be called inside the body of a function component

原因

这个只是个函数,不是组件。
函数组件和函数还是有所区别的。前者会被React编译,最终执行的实质上是React编译后的函数;而后者在未执行时,React可能都不知道它是什么东西。

所以在使用时,必须按照React组件的方式去调用,所以在调用的时候需要这样写:

render() {
	return (
		<Toast />
	)
}

总结

所以在使用的时候hooks还是存在一些局限性的,文章会持续更新在使用中的实际问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值