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

做网站多少钱特惠西宁君博s培训机构有哪些

做网站多少钱特惠西宁君博s,培训机构有哪些,模板网站建站,工作室需要营业执照吗类似 vue 的 data 选项 功能 向组件添加响应式变量,当响应式变量变化时,组件的视图UI也会跟着变化【数据驱动视图】 语法 参数为变量的初始值返回值为一个只有两个元素的数组,第一项元素为传入的参数,第二项元素是一个setter 函数…

类似 vue 的 data 选项

功能

向组件添加响应式变量,当响应式变量变化时,组件的视图UI也会跟着变化【数据驱动视图】

语法

  • 参数为变量的初始值
  • 返回值为一个只有两个元素的数组,第一项元素为传入的参数,第二项元素是一个setter 函数

使用范例 – 响应式变量

import { useState } from "react";
const Demo = () => {const [count, setCount] = useState(0);function addOne() {setCount(count + 1);}return <button onClick={addOne}>{count}</button>;
};export default Demo;
  • 声明了响应式变量 count ,初始值为 0
  • 通过 [] 进行了数组的解构赋值,将 0 赋值给了 count ,可响应式改变 count 值的 setter 函数赋值给了
  • 通过 setCount 可修改 count 的值 (setCount 可以自定义为其他名称,如 updateCount , 但推荐统一 set 开头)
  • setCount 的语法是将 count 的新值作为参数传入
  • setCount 的作用是触发视图根据 count 的新值重新渲染

使用范例 – 响应式对象

  const [person, setPerson] = useState({firstName: 'Barbara',lastName: 'Hepworth',email: 'bhepworth@sculpture.com'});function handleFirstNameChange(e) {// 修改属性值setPerson({...person,firstName: e.target.value});}

修改嵌套的属性值

  const [person, setPerson] = useState({name: 'Niki de Saint Phalle',artwork: {title: 'Blue Nana',city: 'Hamburg',image: 'https://i.imgur.com/Sd1AgUOm.jpg',}});function handleNameChange(e) {setPerson({...person,name: e.target.value});}function handleTitleChange(e) {setPerson({...person,artwork: {...person.artwork,title: e.target.value}});}

显然,非常麻烦,可以用 Immer 库编写简洁的更新逻辑

npm install use-immer
import { useImmer } from 'use-immer';
  const [person, updatePerson] = useImmer({name: 'Niki de Saint Phalle',artwork: {title: 'Blue Nana',city: 'Hamburg',image: 'https://i.imgur.com/Sd1AgUOm.jpg',}});function handleNameChange(e) {updatePerson(draft => {draft.name = e.target.value;});}function handleTitleChange(e) {updatePerson(draft => {draft.artwork.title = e.target.value;});}

使用范例 – 响应式数组

  const [fruitList, setFruitList] = useState([]);function changeHandler(e) {let newValue = e.target.value;if (fruitList.includes(newValue)) {// 数组删除元素setFruitList(fruitList.filter((item) => item !== newValue));} else {// 数组新增元素setFruitList([...fruitList, newValue]);}}
http://www.hengruixuexiao.com/news/26464.html

相关文章:

  • 杭州拱墅区网站建设seo优化软件有哪些
  • 微信公众号广告投放价格表惠州抖音seo
  • 夏津网站建设费用湖人今日排名最新
  • 百度做一个网站怎么做呢网络最有效的推广方法
  • 做网站设计的平台sem竞价托管价格
  • 源码资源网镇江网站关键字优化
  • 无锡做推广的网站百度商城购物
  • 网站建设属于什么支出网站建设公司
  • cms网站访问人数seo网站排名优化快速排
  • 网站商城例子下载大连百度关键词排名
  • 免费建设展示网站seo快排技术教程
  • 镇江网站优化独立站搭建要多少钱
  • 莱山网站建设广州网络营销推广公司
  • 哪些网站布局设计做的比较好的百度 seo优化作用
  • 如何安装字体wordpressseo快速排名软件
  • 可以完成交易的网站 做推广合作
  • 做平面什么网站的素材不侵权泰安seo推广
  • 郑州网站营销推广公司网站排名优化工具
  • 专业做英文网站的公司墨子学院seo
  • wordpress线上聊天插件seo搜索引擎优化哪家好
  • 可喜安cms系统seo域名如何优化
  • 郑州seo优化公司排名seo优化上海牛巨微
  • 用什么工具做网站视图腾讯竞价广告
  • 建设银行发卡银行网站北京百度关键词推广
  • wordpress博客列表显示网站优化
  • 白酒 网站模板新闻源
  • 幼儿园东莞网站建设免费引流人脉推广软件
  • 工装公司联系方式旺道seo
  • 白洋湾做网站公司企业查询系统官网天眼查
  • 网页设计与制作题与答案广州seo推广