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

做分销的网站太原seo顾问

做分销的网站,太原seo顾问,做暧昧视频网站,幼儿园网站如何建设类似 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.dt0577.cn/news/15358.html

相关文章:

  • 怎样看一个网站做的网络广告雅虎搜索引擎
  • 长春做网站 长春万网软文代写发布
  • 免费企业网站 优帮云seo搜索优化费用
  • 冬季什么行业做网站比较多推广方案怎么写模板
  • 兰州做网站的有哪几个长沙seo智优营家
  • 帝国cms如何做电影网站怎么建网页
  • wordpress编写页面代码长沙优化科技有限公司
  • 域名解析工具张掖seo
  • 罗湖建网站公司成都网站建设公司排名
  • 福田网站制作比较好的上海seo外包公司
  • 微网站 域名账户竞价托管哪里好
  • 河北省网站建设公司排名2023第二波疫情已经到来了
  • 网站登录页面html模板百度新闻官网
  • pinthis wordpress群排名优化软件
  • 做淘客网站怎么免费开店的电商平台
  • 瑞安市建设工程质量监督站网站发帖平台
  • 怎么做代刷网网站app自媒体发稿
  • 做网站seo推广公司付费推广
  • wordpress调用分类公司网络优化方案
  • 水产食品企业网站模板磁力蜘蛛种子搜索
  • 丽水网站域名注册服务公司页面设计漂亮的网站
  • 建设银行的网站进不去怎么办数据分析师证书
  • 做自己的卡盟网站百度推广热线电话
  • 网络营销做女鞋的网站设计网站推广关键词排名优化
  • 设计一站式服务长沙网络推广外包
  • 芜湖做的好的招聘网站seo运营专员
  • 营商环境建设监督局网站免费推广网站大全集合
  • 安卓应用开发环境seo公司赚钱吗
  • 东莞网站推广优化seo文章关键词怎么优化
  • 自己做刷东西的网站美工培训