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

wordpress自建站邮箱想做运营怎么入手

wordpress自建站邮箱,想做运营怎么入手,增城网站建设方案,东莞建设银行文章目录 Iframe内嵌相互传递BroadcastChannel同标签页数据传递localStorage中间人传递未完待续... Iframe内嵌相互传递 使用window.postMessage()的这个html5特性去跨域传递数据,不受跨域限制。 父层: sendMes(){ // 向iframe发送let iframdom this…

文章目录

  • Iframe内嵌相互传递
  • BroadcastChannel同标签页数据传递
  • localStorage中间人传递
  • 未完待续...

Iframe内嵌相互传递

使用window.postMessage()的这个html5特性去跨域传递数据,不受跨域限制。

父层:

sendMes(){ // 向iframe发送let iframdom = this.$refs.iframdom // 拿到iframe的domlet _window = iframdom.contentWindow // 拿到iframe的window对象let _document = iframdom.contentDocument // 拿到iframe的document对象_window.postMessage({type: 'sendMes', text: '内容'}, '*') // 注意点:1 第一个参数传内容用对象装,因为webpack会默认主动触发一次,// 即使sendMes没执行,这样被第一次触发的时候我们能通过对象的内容去区分。// 2 第二个参数写传入的地址是什么,如果不限制地址写*即可
}window.addEventListener("message", (e) => { // 接收子层// e.data及postMessage的第一个参数,e.origin及postMessage的第二个参数
})

子层:

window.addEventListener("message", (e) => { // 接收父层// e.data及postMessage的第一个参数,e.origin及postMessage的第二个参数
})sendOut(){ // 向父层发送window.top.postMessage({type: 'sendMes', text: '内容'}, '*') 
}

个人对这个api的看法:

  • 能够支持跨域,这样不同项目的网站都能相互通信了。
  • 当传输的内容多了,整个工程到处都是postMessage,到处监听,会非常的混乱(建议监听统一放到类似App.vue的组文件中)。
  • 父层与子层需要定好规则,例如你的项目是子层,就要去问负责开发父层网站的开发人员,怎么按照他们的规范去传递数据和获取回数据

这里推荐篇基础使用文章:【记录postMessage的详细使用】
再推荐篇补充的:【终于搞懂了 Iframe (跨窗口通信)】


BroadcastChannel同标签页数据传递

这个api适合同一个浏览器中,访问多个标签页,标签页之间的通信:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style></style>
</head><body><button id="btn">点击</button><script>let btnDom = btnconst channel = new BroadcastChannel('card')btnDom.onclick = function () {channel.postMessage({a: 1})}channel.onmessage = (e) => {console.log('监听到信息', e.data);}</script>
</body></html>

当a标签页点击了按钮,b标签页就能够接收到数据。兼容性也很好。

当然在框架中使用有些注意事项:

用添加监听器的方式去监听channel的信息传递,这样好销毁内存

channel.addEventListener('message', handler)
channel.removeEventListener('message', handler) // 销毁

还有一个要注意的,如果postMessage时传入的是框架里的响应式变量是会报错的,传入的时候用…处理下。

综上,最好单独写个js文件去调用BroadcastChannel:

const channel = new BroadcastChannel('demo')export function sendMsg(type, content) {channel.postMessage({type,content,})
}export function listenMsg(callback) {const handler = (e) => {callback && callback(e.data)}channel.addEventListener('message', handler)return ()=>{channel.removeEventListener('message', handler) // 让组件在使用的时候能够得到销毁函数,在生命周期钩子中销毁}
}

localStorage中间人传递

localStorage是可以跨页签的,只要是同域的都共用一个localStorage缓存,利用这个特性可以:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style></style>
</head><body><button id="setData">存储</button><button id="getData">获取</button><script>let setDataDom = setDatalet getDataDom = getDatasetDataDom.onclick = function () {localStorage.setItem('a', 1)}getDataDom.onclick = function () {console.log(localStorage.getItem('a'));}</script>
</body></html>

iframe嵌套相同域名的页面应该也是可以正常使用的,不过

  • 多占用localStorage资源
  • 无法做到主动接收

这里提个醒sessionStorage每个页签都是独立的


未完待续…

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

相关文章:

  • 北京中小型网站建设西乡专业建站
  • 零售网站模板找别人做网站注意事项
  • 南宁网站关键词推广wordpress分页目录编辑
  • 福州专业建站莆田市的网站建设公司
  • 中文网站建设公司排名海淘科技上海网站设计
  • 天津网站制作工具爱网站长尾
  • 网站开发编程的工作方法济南公众平台网站建设
  • 鄂州英文网站建设域名注册网站源码
  • 购物网站图片的放大怎么做的做棋牌网站违法嘛
  • 宁波专业网站推广制作服务深入解析wordpress 原书第2版 pdf
  • 湖南网站托管哪家好网站产品页排名怎么做
  • 深圳市罗湖区住房和建设局网站做名片用哪个网站
  • 木地板企业网站模版专业设计餐厅设计公司
  • html淘宝店铺网站模板wordpress 设计类主题
  • 做网站最主要店铺推广方案怎么写
  • 男女做暖暖插孔网站网站开发流行工具
  • 打渔网站建设wordpress主题原创
  • 产品网站建设多少钱做门的网站
  • 很多搜索词网站怎样做外包网站开发公司
  • 个人怎么做公司网站第三方平台做网站网站
  • 购物网站制作流程网站推广是什么
  • 汉中北京网站建设南阳企业网站排名优化
  • 湛江网站模板山东省住房和城乡建设厅服务网站
  • 网站建设信息服务费计入什么科目公众号运营工作内容
  • 有没有做微场景的网站电话交换机ip地址
  • 网站建设推广代运营网站的底部导航怎么做
  • 网站建设河南品牌策划案例
  • 外贸企业网站红色风格沈阳建设工程信息网 放心中项网
  • 在电脑上怎么建设网站外贸云网站建设
  • wordpress时间做旧佛山网站推广优化公司