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

网站开发技术大学教材wordpress api开发文档

网站开发技术大学教材,wordpress api开发文档,西地那非片有延时效果吗,给别人做网站别人经营违法大家好,我是前端西瓜哥,今天我们来看看 React 的受控组件和非受控组件有什么不同。 受控组件 受控组件,指的是将表单元素的值交给组件的 state 来保存。 例子: import ./styles.css import { useState } from reactconst App …

大家好,我是前端西瓜哥,今天我们来看看 React 的受控组件和非受控组件有什么不同。

受控组件

受控组件,指的是将表单元素的值交给组件的 state 来保存。

例子:

import './styles.css'
import { useState } from 'react'const App = () => {const [val, setVal] = useState('前端西瓜哥')const sumbit = () => {// 直接拿组件 stateconst username = val// ...}return (<div>用户名:<inputvalue={val}onInput={(e) => {setVal(e.target.value)}}/>...</div>)
}

我们用 value prop 控制着 input 元素的值,当发生输入事件时,我们将新值赋值给 val,然后 val 再通过 value 强制更新到 input。

这种写法,可以让 state 一直保持和 input 的内容相同,我们可以直接读取 state,将其传递给其他地方,比如通过 redux 去传递。

缺点是会进行组件的重渲染,一般来说表单元素并不复杂,重渲染成本不高,可以忽略不计。

非受控组件

非受控,就是指状态不由组件的 state 把持,而是让表单元素的内部控制着状态,在我们需要的时候再通过 element.value 的方式取出。

表单元素的初始值通过 defaultValue prop 来设置。

例子:

const App = () => {const ref = useRef(null)const sumbit = () => {// 通过元素的引用取值const username = ref.current?.value// ...}return (<div>用户名:<input ref={ref} defaultValue="前端西瓜哥" />...</div>)
}

优点是不会更新组件。缺点是不方便实时将值传给其他组件。

另外,它适合一种延迟更新状态的场景。比如输入一些内容,回车后失焦,发现格式不合法,就恢复为上一次的值。

结尾

受控组件和非受控组件,区别在于前者的表单状态由组件 state 控制,后者则是表单元素自己控制,要用时再读元素的值。

我是前端西瓜哥,欢迎关注我,学习更多前端知识。

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

相关文章:

  • 晋城网站建设电话物流网个人网站建设
  • 河源市seo网站设计c2c商城网站建设公司
  • 阜宁做网站哪家最好西安网络推广外包公司
  • 网站建设兆金手指科杰平顶山车祸最新新闻事件
  • 嘉兴制作网站软件长泰微新闻
  • 快站淘客小程序开发定制北京公司
  • 建设网站商城国外点击链接推广平台
  • 企顺网网站建设做红木家具推广哪个网站比较好
  • 最成功的个人网站最火爆的网页游戏
  • 广州企业推广网站建设dede网站地图xml
  • 建站知识怎么制作网页教程步骤
  • 长春网站制作推广做网站怎么自定义背景图片
  • 怎么做盗版电影网站企业门户网站建设行情
  • 网站图表怎么做的做网站参考文献
  • 网站建设 wordpress系统越南注册公司需要什么条件
  • 官方网站平台下载大数据营销案例分析
  • 安庆专业做淘宝网站手机上page转换wordpress
  • 网站升级建设费用现在房地产的最新情况
  • 深圳深圳做网站怎么用自己的电脑做网站空间
  • iis 与 wordpress西安专业seo
  • 长安网站建设网络推广工业信息化部网站备案
  • 网站运营 流程360官网首页入口
  • 注册一个网站英迈寰球网站建设
  • 北京网站开发浩森宇特网站免费优化工具
  • p2p网站建设源码网站首页图片做多大
  • 无锡新区企业网站推广wordpress搬家
  • 一元夺宝网站怎么做天津通用网站建设收费
  • 网站集约建设原因榆林 网站建设
  • 蓬莱做网站那家好西部虚拟主机网站后台不能访问
  • dw网站根目录怎么做学做会计账的网站