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

批量做网站软件一个新品牌怎样营销推广

批量做网站软件,一个新品牌怎样营销推广,做与不做赞美网站,网站应急响应机制建设【React】react组件传参 一、props:父组件向子组件传参1、将普通的参数作为props传递2、将jsx作为props传递(组件插槽)(1)基础功能示例(2)进阶示例 二、自定义事件:子父组件向父组件…

【React】react组件传参

  • 一、props:父组件向子组件传参
    • 1、将普通的参数作为props传递
    • 2、将jsx作为props传递(组件插槽)
      • (1)基础功能示例
      • (2)进阶示例
  • 二、自定义事件:子父组件向父组件传参
  • 三、context进行多级组件传参
  • 四、redux全局状态管理

一、props:父组件向子组件传参

  • 所有props是单向的,对于子组件来说,父组件传过来的数据都是只读的,所有不要尝试做修改

1、将普通的参数作为props传递

function Child(props: { name: String }) {const { name } = props;return (<div  style={{border:'1px solid'}}><h3>我的子页面</h3>{name}</div>);
}
function App() {return (<div><h2>标题:父组件向子组件传参</h2><Child name={"我是父组件传过来的参数"} /></div>);
}

在这里插入图片描述

2、将jsx作为props传递(组件插槽)

  • 父组件可以向子组件传递一些普通的值以外,还可以传递以下jsx,那这就不得不提到插槽的概念,如以下代码,就是利用jsx语法实现了所谓的一个插槽的概念

(1)基础功能示例

function List(props:{children:any}) {
//children会接受父元素开始和结束标签之间的内容const {children}=propsreturn <div>{children}</div>;
}
function App() {return (<div><List><li>列表项1</li><li>列表项1</li><li>列表项1</li></List><List><li>列表项2</li><li>列表项3</li><li>列表项3</li></List></div>);
}

在这里插入图片描述

(2)进阶示例

  • 向多个位置传递jsx
function List(props: any) {//title,footer如果是可选的注意要设置默认值//如果不设置的话或包语法错误,我这里title是必选const { children, title, footer = <div>默认底部</div> } = props;return (<><h2>{title}</h2><ul>{children}</ul><div>{footer}</div></>);
}function App() {
// 优化:这里应该将下面的列表处理成一个数组包含对象的形式进行map渲染return (<div><List title="列表1" footer={<p>底部1</p>}><li>列表项1</li><li>列表项1</li><li>列表项1</li></List><List title="列表2"><li>列表项2</li><li>列表项2</li><li>列表项2</li></List></div>);
}

在这里插入图片描述

二、自定义事件:子父组件向父组件传参

  • 通过父组件给子组件设置自定义事件,然后通过事件触发向父组件传递参数;
function Detail(props: any) {const { onActive } = props;//status为控制Detail的内容显示不显示const [status, setStatus] = useState(false);function handClick() {setStatus(!status);//将参数status传给父组件onActive(status);}return (<><button onClick={handClick}>按钮</button><p style={{ display: status ? "block" : "none" }}>Detail的内容</p></>);
}
function App() {function handActive(status: any) {// status就是子组件传过来的参数console.log(status);}return (<div>{/* 给子组件绑定一个自定义事件onActive */}<Detail onActive={handActive} /></div>);
}

在这里插入图片描述

三、context进行多级组件传参

import { createContext,useContext } from 'react';

createContext:在任意组件外调用 createContext 创建一个上下文,createContext 返回一个上下文对象
useContext: 是一个 React Hook,可以让你读取和订阅组件中的 context。

import React, {useContext,createContext } from 'react';
//创建 context对象
//createContext 参数  可以进行初始化操作
const MyContext= createContext(null);//Child子组件
//const 公共数据 = useContext(Context) 这里的公共数据就是根组件value的值
function Child() {const color = useContext(MyContext);return <div><h3>我的子页面</h3>颜色值是:{color}<hr /><Child1 /></div>
}//Child1子子组件
//const 公共数据 = useContext(Context) 这里的公共数据就是根组件value的值
function Child1() {const color = useContext(MyContext);return <div><h3>我的子子页面</h3>颜色值是:{color}</div>
}function App() {return (// value={ 这里放要传递的数据 }<MyContext.Provider value={"yellow"}><div><h2>useContext</h2><Child /></div></MyContext.Provider>)
}
export default App;

结论:

  • Child和Child1都拿到了”yellow“
  • useContext会在context值变化时重新渲染,<MyContext.Provider>的value发生变化时,包裹着的子组件无论是否使用value值,都会重新渲染。
    可以使用memo对未使用value的子组件进行优化,在组件更新的时候memo会检测自身包裹的组件是否有数据更新,如果没有,就会阻止自身组件的重新渲染,减少性能损耗。
    在这里插入图片描述

四、redux全局状态管理

http://www.dinnco.com/news/17208.html

相关文章:

  • 杭州网站建设是什么seo推广专员招聘
  • 小蘑菇网站建设软件上海网络推广招聘
  • 互联网网站制作网站广告收费标准
  • 学做网站要什么基础网站优化方案怎么写
  • 用python做网站开发的课程seo快速排名系统
  • 品牌建设计划seo快速排名优化方法
  • html网页设计作业成品代码免费下载网络网站推广优化
  • wordpress照片模糊seo链接优化建议
  • 营销型网站建设的特色亚马逊关键词
  • 地方门户网站建设要求百度热搜的含义
  • 微网站 建设友情链接交换源码
  • php网站做分享到朋友圈不受限制的搜索浏览器
  • wordpress关注公众号搜索引擎优化宝典
  • 福田网站建设设计公司环球军事新闻最新消息
  • 电子商务网站推广论文百度推广效果怎样
  • 网站价格网页制作互联网营销推广方案
  • jsp网站首页那栏怎么做百度关键词价格
  • 墓地网站建设价格公司网站设计方案
  • 中怎么做网站上下载图片的功能微信推广图片
  • 美国做美业网站的么特网络营销公司名字
  • 关于校园网站建设的通知今天的头条新闻
  • 更改wordpress菜单字体seo对网店推广的作用
  • 中国做网站最好的企业百度点击器找名风软件
  • 东莞市第一人民法院武汉seo技术
  • 吉林市网站创意与建设深圳外贸网络推广渠道
  • 网站开发需要redis近期的时事热点或新闻事件
  • 昆山网站建设价格如何做网站搜索引擎优化
  • 自己可以接单做网站吗手机怎么创建自己的网站平台
  • 用python做的网站多吗线上招生引流推广方法
  • 广告设计网站素材各个广告联盟的标识