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

如何用文档创建一个网站山西seo排名厂家

如何用文档创建一个网站,山西seo排名厂家,word直接复制到wordpress,济南做网站建设的公司一、需求分析 最近做的一个用H5加原生开发的html项目,现需要集成到Vue2.0项目里面来。遇到的相关问题做个记录和总结,以便能帮到大家避免踩坑。 二、问题记录 1、页面空白问题 将html页面通过iframe的方式嵌入进来之后,发现页面是空白的&am…

一、需求分析

      最近做的一个用H5加原生开发的html项目,现需要集成到Vue2.0项目里面来。遇到的相关问题做个记录和总结,以便能帮到大家避免踩坑。

二、问题记录

1、页面空白问题

     将html页面通过iframe的方式嵌入进来之后,发现页面是空白的,不显示任何元素,

通过搜索资料发现,把html页面放到public目录下面的static目录下能够显示

 

 不写static目录直接访问会报错

2、vue和html页面之间如何通信

首先通过window对象 绑定一个方法 去调用vue声明的方法 

格式为:window[‘方法名’]   = (参数)=>{  vue里面的 你需要在html页面里调用的方法  }

下面是贴的相关代码 三个方法

methods: {// 调用方法iframeLoad() {const iframe = document.querySelector('#iframe')this.loading = trueconst that = this// 兼容处理if (iframe.attachEvent) {// IEiframe.attachEvent('onload', () => {that.loading = false})} else {// 非IEiframe.onload = () => {that.loading = false}}},//查询机组下拉列表listSystemQuery(){listSystem().then((response) => {this.selectData = response.rows || [] //机组下拉列表this.sendMessage(1)}).catch((error)=>{console.log(error)})},//查询所选机组下的查询参数listParamsQuery(param){const value = param.valueconst number = param.numgetSystemResult(value).then((response) => {this.paramsData = response.data || [] //所选机组参数this.sendMessage(2,number)}).catch((error)=>{console.log(error)})},//点击查询按钮获取对标分析数据dbfxQueryData(param){const params = {id: param.id,startTime: param.startTime, //开始时间endTime: param.endTime,   //结束时间queryParams: param.queryParams,timeParam: param.timeParam,//页面录入 持续时间秒}const num = param.numgetSystemData(params).then((response) => {this.resultData = response.data || [] //所选机组参数this.sendMessage(3,num)}).catch((error)=>{console.log(error)})},sendMessage(num,num2){const iframeWindow = document.querySelector('#iframe').contentWindowif(num===1){iframeWindow.postMessage({cmd: 'selectData',params: {success: true,data: this.selectData,}},'*')  // 发送消息至html页面}else if(num ===2){iframeWindow.postMessage({cmd: 'paramsData',params: {success: true,data: this.paramsData,num:num2}},'*')  // 发送消息至html页面}else if(num ===3){iframeWindow.postMessage({cmd: 'resultData',params: {success: true,data: this.resultData,num:num2}},'*')  // 发送消息至html页面}},}

在vue绑定方法之后 那么如何在html去调用这个方法呢

通过window.parent['vue里面绑定的名称'](需要传递的参数)  可以定义一个对象来传参 这种方法就可以调用到vue里面的方法啦!

       //调用vue方法const param ={value:selectValue,num:num}window.parent['queryParamsData'](param)

如下 html调用的是这个方法 

 param可以接收到来取值

 html调用vue现在可以拿到数据啦   那么该如何回传到html页面上来使用呢 看下面!

 首先拿到iframe的contentWindow对象,通过这个对象 postMessage 就可以发送消息给到html页面

 html页面接收时是通过message统一接收的,针对发送多个消息的情况下, 我们这里做下区分,

 通过传递不同的参数作为标识来区分是那个接口来发送的消息

html页面同样也要根据传递过来不同的参数 去调整自己的逻辑,首先知道html是如何接收到vue传来的消息的,window监听message即可接收postMessage发送来的消息

再通过传参的不同就可以区分处理逻辑啦

 3、iframe延迟加载提升用户体验

如果不加加载效果,会导致dom元素渲染的很慢,体验感很差,这里通过antdesign的spin渲染组件来搞定它

 那么问题来了,什么情况下知道iframe渲染完了呢,看下面

 iframe对象attachEvent事件可以知道是否已加载完成,再去给他关闭loading即可

 

http://www.hengruixuexiao.com/news/15956.html

相关文章:

  • 景区网站建设方案市场推广怎么写
  • 外国网站打开慢怎么办网络热词排行榜
  • 阿里云这么建设网站市场调查报告模板及范文
  • 南充网站建设略奥网络品牌推广与传播怎么写
  • 为一个村做网站网页查询
  • 泉州最专业手机网站建设开发网站测速
  • 做3d任务的网站怎么做一个属于自己的网站
  • 网站怎么做电脑系统浏览器网页版入口
  • 平面设计创意图南宁百度关键词优化
  • 怎么做公司网站需要什么科目孝感seo
  • 海口做网站供应商电脑上突然出现windows优化大师
  • 北京新站优化什么推广方法是有效果的
  • 电商网站seo方案武汉网站推广优化
  • ppt做的好的网站有哪些内容网店推广方案
  • 制作图片用什么软件好用东莞整站优化推广公司找火速
  • 宁波网站建设优化找哪家营销策略怎么写模板
  • 国外有什么做网站的软件吗武汉网站seo
  • 佛山新网站建设平台河南seo和网络推广
  • 美女和男人做鸡的网站广州seo网站
  • 新公司网站建设流程最有效的15个营销方法
  • 自己做的网站怎样弄网上搜索引擎优化到底是优化什么
  • 网站建设 北京关键词挖掘长尾词
  • 香港台湾人做攻略用什么网站竞价推广论坛
  • 有没有网站教做美食的网站域名查询网
  • 手机建网站公司seo综合诊断工具
  • 电子商务网站的建设和维护网站google搜索优化
  • 传统网站设计seo教程免费
  • 三把火科技网站设计杭州正规引流推广公司
  • 什么主题的网站容易做点seo公司官网
  • 互联网网站制作电商平台怎么搭建