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

网站建设付款方式苏州seo公司

网站建设付款方式,苏州seo公司,网页微信版传输助手,培训行业网站建设的重要性文章目录 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.yidumall.com/news/5072.html

相关文章:

  • 网站附件下载表格怎么做杭州网站推广找哪家
  • 怎么做网站不被发现职业技能培训网
  • seo教程自学seo关键词排名注册价格
  • 企业做网站被骗太原网站推广公司
  • 做黄网站有哪些福州seo扣费
  • 重庆营销型网站开发公司电话最简单的营销方案
  • 如何制作外贸网站 wordpress百度用户服务中心人工电话
  • 南京行业网站建设互联网广告联盟
  • 在国外网站做中国旅游推广全网营销一站式推广
  • 打折网站建设教程下载网络销售就是忽悠人
  • 做网站衡水百度一下百度主页
  • 用dw做音乐网站系统的代码软文例文 经典软文范例
  • 免费推广网站入口202旺道seo系统
  • 网站建设wix樱桃bt官网
  • 购物网站建设投资预算电商seo是什么意思
  • 旅游产业网站app建设的市场分析seo搜索引擎优化人员
  • 企业网站建设的思路域名批量查询系统
  • 网站备案域名还是空间查网站域名
  • 厦门旋挖建筑公司网站网站推广是什么
  • 深喘旋磨做紧夹断妖精网站搜索引擎营销经典案例
  • 网站建设书店目标客户分析互联网广告优化
  • 优秀企业网站建设价格天津百度seo代理
  • 自己做的网站在浏览器上显示不安全吗广告投放网
  • 包头北京网站建设佛山seo培训机构
  • 尺寸在线做图网站seo综合查询工具
  • 自己做网站的视频北京培训机构
  • 个人网站怎么盈利北京网站优化方案
  • 网站推广的看法重庆seo全网营销
  • 前端学校网站开发视频腾讯企点怎么注册
  • 深圳 网站建设培训班可以免费发广告的网站有哪些