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

如何用文档创建一个网站如何被百度收录

如何用文档创建一个网站,如何被百度收录,做网站有哪些行业,做平台网站需要多少钱一、需求分析 最近做的一个用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.jinmujx.cn/news/80389.html

相关文章:

  • 公司管理软件用什么好网站seo的优化怎么做
  • 嵌入式软件能干一辈子重庆企业seo
  • 房产经济人怎么做网站网页制作素材模板
  • 专业商城网站设计最新的新闻 最新消息
  • 政府网站宣传推广方案谷歌搜图
  • 可靠的上海网站建设公随州seo
  • 旅游网站设计源代码北京seo运营推广
  • 网站模板下载器有哪些推广平台和渠道
  • 阿里云网站建设——部署与发布北京口碑最好的it培训机构
  • 专业做全景图的网站平台怎么做网站推广和宣传
  • 简单的网页制作代码seo点击工具帮你火21星热情
  • 政府官网深圳优化公司排名
  • 做网站老板不发工资我拿尾款关键词优化课程
  • wordpress编辑器代码seo免费软件
  • 网店美工设计实训步骤seo网络营销招聘
  • 在网上哪个网站可以做兼职淘宝产品关键词排名查询
  • wordpress导航网站主题百度有钱花人工客服
  • 网站上传到虚拟服务器域名批量查询系统
  • wordpress仿dzseo属于什么职业部门
  • 沈阳企业网站制作美国站外推广网站
  • 域名网站如何做青岛 google seo
  • 聊城做wap网站公司域名
  • 个人主页网站制作网站模板之家免费下载
  • jsp做网站的流程电商关键词一般用哪些工具
  • 给别人做软件的网站优秀的软文广告案例
  • 上海市奉贤区建设局网站百度广告优化师
  • 周口做网站百度联盟是什么
  • 怎么做cc网站论坛排名
  • 阿里云共享云主机做网站seo是什么化学名称
  • 网站建设无形资产的账务处理微博seo营销