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

公司网站建设网站合肥网页设计哪家服务好

公司网站建设网站,合肥网页设计哪家服务好,汕头老城区图片,肉多各种地方做的网站在nextjs项目中#xff0c;发现两个组件没啥关系#xff0c;例如一个是一直存在的头部组件#xff0c;另一个是页面中的组件#xff0c;当我点击头部组件中的特定按钮时#xff0c;把数据传递到页面组件中#xff0c;页面组件接受到canshu数据后在做其他操作#xff0c;…在nextjs项目中发现两个组件没啥关系例如一个是一直存在的头部组件另一个是页面中的组件当我点击头部组件中的特定按钮时把数据传递到页面组件中页面组件接受到canshu数据后在做其他操作那么他们两个如何通讯通过context配合观察者模式实现。 首先在其共同的祖先组件中使用context 下面的代码文件是根路由组件Layout.js 其中children就是根据路由渲染的对应的页面 .... import {ConContext} from ../utils/test1; import EventBus from ../utils/test; const Layout () { ConContext.Provider value{EventBus()}Header /{children}Footer/Footer/ConContext.Provider } export default Layouttest1.js 创建context import { createContext } from react;export const ConContext createContext(null); test.js 使用 useEffect 包装下否则会在服务端渲染而服务端又没有浏览器对象所以会报错导致打包失败下面代码中注释的代码就会报找不到document所以使用useEffect包装下创建了一个自定义hook勾子 useEvent这个钩子创建一个变量用于接收EventBus这个类为什么要在useEffect 创建EventBus呢因为只有在useEffect中才能拿到浏览器对象然后在返回变量。然后导出这个useEvent use client import {useEffect, useState} from react // 使用 useEffect 包装下否则会在服务端渲染而服务端又没有浏览器对象所以会报错导致打包失败 const useEvent () {const [val, setVal] useState()useEffect(() {class EventBus {constructor() {this.bus document.createElement(fakeelement);}addEventListener(event, callback) {this.bus.addEventListener(event, callback);}removeEventListener(event, callback) {this.bus.removeEventListener(event, callback);}dispatchEvent(event, detail {}){this.bus.dispatchEvent(new CustomEvent(event, { detail }));}}setVal(new EventBus)},[])return val }export default useEvent// use client // class EventBus { // constructor() { // this.bus document.createElement(fakeelement); // }// addEventListener(event, callback) { // this.bus.addEventListener(event, callback); // }// removeEventListener(event, callback) { // this.bus.removeEventListener(event, callback); // }// dispatchEvent(event, detail {}){ // this.bus.dispatchEvent(new CustomEvent(event, { detail })); // } // }// export default new EventBus在header中触发事件 header.js 使用useContext接收数据 import React, {useState, useContext} from react; const Header () { const EventBus useContext(ConContext) // 点击按钮时触发const clickTab (url) {setOpenMenu(false)// 点击头部菜单切换轮播图开始// EventBus.dispatchEvent(myEvent, {log: 2})// 点击头部菜单切换轮播图结束push(url)} } export default Header在对应的页面组件中接收myEvent这个自定义事件 import React, { useEffect,useRef, useContext } from react; import { ConContext } from ../../utils/test1; const Products (props) { const EventBus useContext(ConContext) console.log(EventBus,EventBus); const slider useRef(); const handleEvent (e) {slider.current.goTo(e.detail.log)} useEffect(() {EventBus.addEventListener(myEvent, handleEvent)}, [EventBus]); }export default Products;参考10种React组件之间通信的方法
http://www.huolong8.cn/news/213904/

相关文章:

  • 上海企业网站制作费用农业信息网站建设
  • 寺庙网站建设方案深圳做网站比较
  • 网站建站网站开发wordpress更改ip地址后图片处理
  • 自适应网站一般用什么框架做怎么做自己的单页网站
  • 网站小编可以在家做吗百度广告联盟推广链接
  • 优化 导航网站wordpress term_group
  • 中专网站建设课程安徽省省建设厅网站
  • 淘宝客怎么做推广网站品牌和网站建设
  • 网站备案期间访问上海网站制作官网
  • 神州顺利办深一做网站绿色为主色的网站
  • 教育网站制作公司做一个线上app多少钱
  • 做网站一共需要多少钱长沙专业竞价优化公司
  • 用树莓派做网站服务器青岛房产网签查询系统
  • 深圳创业贷款条件申请及流程百度seo排名优化排行
  • 京东网站建设框架图色盲眼镜
  • 比较好的网站建设技术开发想做个网站不知道做什么
  • 电子商务网站开发 什么框架建站管理后台
  • 进入城乡建设网站怎么竣工备案做一个个人网站多少钱
  • wordpress网站源码分享兰州家政公司
  • 网站制作中搜索栏怎么做6如何打开用wordpress
  • 驻马店网站网站建设免费ps软件手机版
  • 电器工程东莞网站建设广州官方网站建设
  • 定机票最便宜网站建设wordpress 预览插件下载
  • 用凡科做的网站怎么下载郴州网站建设哪里比较好
  • 网络建站公司如何做市场兼职网站开发一个月
  • 网站,商城,app 建设重庆一次可以备案多少个网站
  • asp网站建设流程山东省建设安全生产协会网站
  • 如何搭建情侣网站网络科技公司可以去吗
  • 论网站建设情况电商网站建设好么
  • 做网站数据库设计线上推广的意义