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

网站建设好如何开通做网站360推广多少钱

网站建设好如何开通,做网站360推广多少钱,企业门户是什么,软件研发过程管理React Hooks 1. 使用hooks理由 高阶组件为了复用,导致代码层级复杂生命周期的复杂 2. useState(保存组件状态) const [state, setstate] useState(initialState)3. useEffect(处理副作用)和useLayoutEffect(同步执行副作用) 使用方式: useEffect(…

React Hooks

1. 使用hooks理由

  1. 高阶组件为了复用,导致代码层级复杂
  2. 生命周期的复杂

2. useState(保存组件状态)

const [state, setstate] = useState(initialState)

3. useEffect(处理副作用)和useLayoutEffect(同步执行副作用)

  1. 使用方式:
useEffect(() => {// effectreturn () => {// cleanup};
}[依赖的状态;空数组,表示不依赖])
  1. 说明:
  • 不传入依赖:对比componentDidMount生命周期,表示初始加载完后执行
  • 传入依赖:对比componentDidMountcomponentDidUpdate生命周期,表示加载完后和更新完成后执行
  • 回调函数内return函数,对比componentWillUnmount销毁生命周期
  1. 示例:
useEffect(()=>{const timer = setInterval(()=>{console.log('这是定时器')}, 1000)return ()=>{console.log('componentWillUnmount销毁时触发')clearInterval(timer)}
},[name])
  1. useEffectuseLayoutEffect区别:

简单来说就是调用时机不同,useLayoutEffect和原来componentDidMount & componentDidUpdate一致,在react完成DOM更新后马上同步调用代码,会阻塞页面渲染。useEffect则是在整个页面渲染完才会调用代码

官方优先建议使用useEffect

在实际使用时如果想避免页面抖动(在useEffect里修改DOM很有可能出现)的话,可以把需要操作的DOM的代码放在useLayoutEffect里,在这里做DOM操作,这些DOM修改会和react做出的更改一起被一次性渲染到屏幕上,只有一次回流、重绘的代价

4. useCallBack(记忆函数)

防止因为组件重新渲染,导致方法被重新创建,起到缓存作用,只有第二个参数变化了,才重新声明一次

var handleClick = useCallback(()=>{console.log(name)
},[name])<button onClick={()=>handleClick()}>点击</button>// 只有name改变后,这个函数才会重新声明一次
// 如果传入空数组,那么就是第一次创建被缓存,如果name后期改变了,拿到的还是老name
// 如果传第二个参数,每次都会重新声明一次,拿到的就是最新的name

5. useMemo(记忆组件)(可以理解为Vue的计算属性)

useCallBack的功能完全可以由useMemo所取代,如果你想通过使用useMemo返回一个记忆函数也是完全可以的。

useCallback(fn, inputs) is equivalent to useMemo(()=> fn, inputs)

唯一的区别是:useCallback不会执行第一个参数函数,而是将它返回给你,而useMemo会执行第一个函数并将函数执行结果返回给你。所以在前面的例子中,可以返回handleClick来达到存储函数的目的。
所以useCallback常用记忆事件函数,生成记忆后的事件函数并传递给子组件使用。而useMemo更适合经过函数计算得到一个确定的值,比如记忆组件。

const getFilterList = useMemo(()=> list.filter(item => item.name.toUpperCase().includes(text.toUpperCase())),[list, text] // 如果list和text变化)

6. useRef(保存引用值)

  1. 设置ref属性值
const myRef = useRef(null)
<Child ref={myRef}/>
  1. 用于缓存一个变量值
const [name, setName] = useState('zhangsan')
var mycount = useRef(0)
<button onClick={()=>{setName('lisi')mycount.current++
}}>点击</button>
{name}-{mycount}

7. useReduceruseContext(减少组件层级)

  1. useContext用于组件通信,接收父组件传入的值
// 父组件
import React from 'react'
var GlobalContext = React.createContext()function App(){<GlobalContext.Provider value={{name: '张三',age: 20,changeAge: (value) => {setAge(value)}}}><Child /></GlobalContext.Provider>
}// 子组件内
function Child(){const text = useContext(GlobalContext)
}
  1. useReducer:实现Reduxreducer的功能,应用在组件通信中
const reducer = (prevState, action)=>{const newState = { ...prevState }switch(action.type){case 'add':newState.count ++return newStatecase 'minus':newState.count -- return newStatedefault:return prevState}
}
const initialState = {count: 0
}
// FC中const [state, dispatch] = useReducer(reducer, initialState)<button onClick={()=>{dispatch({type: 'minus'})}}>-</button>{state.count}<button onClick={()=>{dispatch({type: 'add'})}}>+</button>

8. 自定义hooks

当我们想在两个函数之间共享逻辑时,我们会把它提取到第三个函数中。
必须以use开头吗?必须如此。这个约定非常重要。不遵循的话,由于无法判断某个函数是否包含其内部Hook的调用,React将无法自动检查你的Hook是否违反了Hook的规则

http://www.yayakq.cn/news/233449/

相关文章:

  • 简述商务网站建设的步骤游戏开发软件有哪些
  • 网站后台维护主要做什么表白网站制作平台
  • 网站优化改动怎么做wordpress免费资源模板
  • 学做网站医药电商网站建设
  • php手机网站模板用什么软件做楼盘微网站
  • 遵化市城乡建设规划局网站永久免费自助建站推荐
  • 2019做网站赚钱么秦皇岛网站开发公司
  • 网站建设数据库ER图怎么画做羽毛球网站
  • 滨湖网站制作福利站wordpress
  • 团工作网站建设意见合肥网站建设之4个细节要注意事项
  • 移动端漂亮网站wordpress 行距
  • 北京网站建设appwordpress怎么用啊
  • 学校网站建设措施嘉兴公司网站模板建站
  • 带询盘外贸网站源码卖菜网站应该怎么做
  • 网站域名备案需要什么企业网站收费
  • 公众号排版设计seo静态页源码
  • 网站制作需要哪些如何做exo网站
  • 电商网站设计注意事项wordpress的菜单和页面
  • me微擎怎么做网站百度软文推广怎样收费
  • 双语企业网站营销型网站标准网页源码
  • 企业门户网站建设情况汇报始兴县建设局网站
  • 编程学习入门网站wordpress中文广告
  • 网站建设销售工作怎么样怎样申请一个免费网站
  • 临海网站设计济南做网站互联网公司排名
  • 网站搭建流程网站的切换语言都是怎么做的
  • 温岭专业自适应网站建设网站模块建设建议
  • 云南云南住房和城乡建设厅网站在线制作gif表情包
  • 做设计找图有哪些网站有哪些机械建设网站制作
  • 企业网站模板文件管理网站建设合作合同
  • 深圳建站公司南宁建站模板源码