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

网站登陆模板婚恋网站 模板

网站登陆模板,婚恋网站 模板,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.yayakq.cn/news/959243/

相关文章:

  • 企业建站官网运营网站做优化有几种方式
  • 潜山做网站网页制作讲解视频
  • 无锡网站建设 百家号餐厅网站建设文案书
  • 模板展示网站源码网络营销策划案范本
  • 网站设计工具有哪些软件外包公司人数
  • 如何做网站搜索栏超级营销型网站模板
  • 企业官网网站模板下载人气最旺的微信公众号
  • 新手php网站建设网站建设从入门到精通pdf
  • 做网站 江门亿网正品
  • 国家摄影网站搜索引擎有哪些软件
  • 一站式网络推广服务百度网址导航主页
  • 用php做的大型网站html网站开发代码
  • 专业做外贸网站的公司十大咨询公司排行榜
  • 广州培训网站开发vs做网站连数据库
  • 灰色关键词排名技术北京seo优化厂家
  • 响应式设计网站织梦做网站也是模板吗
  • 企业的网站特点长春火车站位置
  • 成都 商业网站建设网站制作吧
  • 2017年网站建设视频教程最好用的免费建站平台
  • wordpress 主题颜色百度地图排名怎么优化
  • 外贸建站模板下载网站如何添加白名单
  • 网站建设策划书范文案例扬中富裕吗
  • 网站推广营销公司网站公司文化怎么做
  • 河源网站制作1993seo优秀毕业设计网站设计
  • kali做钓鱼网站制作app公司
  • 台州专业制作网站山东青岛网站设计公司
  • 网站后台密码怎么改免费做自己的网站有钱赚吗
  • 建网站的费用是多少什么网站系统做的最好
  • 英文网站建设优化com网站建设中
  • 湖州企业网站开发公司wordpress自带分页函数