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

如何用文档创建一个网站seo关键词优化推广

如何用文档创建一个网站,seo关键词优化推广,招聘网站开发兼职,公安局 网站备案查询系统一、需求分析 最近做的一个用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.ds6.com.cn/news/123868.html

相关文章:

  • 网站正在建设中 英语百度风云排行榜
  • 做环境设计的网站seo网站推广什么意思
  • 购物网站建设毕业论文企业网站制作与维护
  • html5新闻网站模板西安网站建设平台
  • 关于网站开发的商业计划书郑州见效果付费优化公司
  • 金融 网站 源码泰州网站建设优化
  • wordpress 插件 摘要沈阳seo优化排名公司
  • 免费头像生成制作网站网站seo关键词设置
  • 做网站网络合同网络营销网站推广
  • 网站群建设论文知乎小说推广对接平台
  • 做网站相关人员安卓手机游戏优化器
  • 制作企业网站的公司体彩足球竞彩比赛结果韩国比分
  • 网站模板模仿b2b平台有哪些
  • 山西网站建设网站建设优化公司
  • 公司在东莞建设网登记要多少钱搜云seo
  • 用照片做视频的网站抖音搜索关键词推广
  • 如何把代码放在网站首页教程公司做网站怎么做
  • 美国哪个网站做diy电脑东莞seo
  • 网站建设太金手指六六二五精准信息300099
  • ssh实训做网站代码下载网店推广运营
  • 龙岩网站推广营销合肥百度seo代理
  • 金融网站建设成功案例百度指数免费查询入口
  • 办个人网站租空间今天的新闻有哪些
  • 武进网站建设价位关键词调整排名软件
  • 商丘网络杭州seo运营
  • 如何成为一个电商seo排名优化课程
  • 人才市场网站建设论文查关键词排名网
  • 将网站加入小程序推广普通话文字素材
  • 中原区建设局网站一键优化免费下载
  • 怎么做网站版面分析百度指数批量获取