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

档案网站建设经验整合营销公司排名

档案网站建设经验,整合营销公司排名,建设个人网站第一步这么做,wordpress网站聊天插件今天下午是一个非常痛苦的,想要实现一个功能: 父页面打开了一个新的页面(浏览器打开一个新的窗口),并在子页面提交数据之后,父页面的数据要同步更新。 难点:父页面是一个表格列表,…

今天下午是一个非常痛苦的,想要实现一个功能:

父页面打开了一个新的页面(浏览器打开一个新的窗口),并在子页面提交数据之后,父页面的数据要同步更新。

难点:父页面是一个表格列表,有分页功能,更新数据之后,要保证页面还在原来的页面。

把子页面关闭之后返回原来的页面,更新对应数据。

简单说下最开始使用的方法,以及最终采用方法,中间尝试的方法暂时略过不谈了…

  1. 关闭当前窗口,强制刷新父页面
    window.opener.location.reload();刷新父窗口
    window.close();关闭当前窗口
    

    上面两行代码网上推荐的比较多的,但是存在问题:

    1. window.opener意思是当前浏览器窗口的打开者,就是指父窗口。window.opener.location.reload()强制刷新了父窗口,也就是说,并不会保留父窗口原有的状态。
    2. window.close();只是单纯的将当前窗口关闭了,焦点并不一定会回到父窗口。(若是打开子窗口的时候,同时打开了其它网页的窗口,关闭子窗口,焦点可能回到你刚刚浏览过的窗口)

在实现这个功能的时候,尝试过诸如以下方法:

  1. 利用浏览器缓存父窗口参数,带参数刷新父窗口。

  2. 在子组件内调用父窗口的方法(因为不是直接父子组件的关系,还尝试利用中间组件实现子组件内调用父组件方法)。

  3. 在子组件内调用父窗口的方法(第二个方法没有成功,又尝试了将父组件方法暴露给window对象也没成功)。

  4. 成功解决问题

尝试了很多方法多没有成功,我又回到了起点,开始分析问题。

分析之后发现其实这个大问题可以分为两个小问题:

  1. 子窗口关闭后,焦点需要回到父窗口;
  2. 焦点回到父窗口后,父窗口需要带状态刷新页面。

那我就一一攻破,首先是第一个小问题,查到了一些资料之后,发现可以实现,代码如下:

  1. 子窗口关闭,焦点回到父窗口

    我的功能都是基于vue项目的,所以代码结构都是基于vue

    // 父窗口文件中
    mounted() {// 设置当前窗口的名字,便于当某些窗口页面关闭时,跳回当前窗口window.name = 'home';
    }// 子窗口文件中,可以写在某一个方法中
    // 回到父窗口home页面
    window.open(window.opener.location.href, window.opener.name);
    // 关闭当前浏览器
    window.close();
    

    第一步实现了,我能正确的回到父窗口了,但是父窗口的对应数据并没有刷新。

  2. 父窗口需要带状态刷新页面

    父窗口文件代码如下:

    methods: {handleVisiable(e){if(e.target.visibilityState === 'visible') {this.initData();}}
    },
    mounted() {// 设置监听,当本页面打开的新页面关闭时,触发事件document.addEventListener('visibilitychange', this.handleVisiable);
    },
    

    这样便实现了对应的功能。

    正当我准备提交测试时,客户的需求变了,计划赶不上变化呀!!,客户要求:

    在页面关闭的时候,先倒计时5秒,之后再关闭。

    我查了一些资料,发现浏览器有保护机制,除了用户直接点击的链接或按钮跳转,浏览器不会拦截,其它浏览器都会拦截。

    也就是说:

    设置一个定时器,定时器时间结束后,触发方法回到父窗口并关闭当前页面的逻辑不得行了。

    关闭窗口的方法能够起作用,但不一定会回到父窗口了,这肯定不行。

    后来找了一些资料的实现方法

    说是在页面上设置一个隐形按钮,满足条件之后触发这个按钮。我尝试过这种方法,这种方法跳转时父窗口时,相当于重新访问了一下,并不会带状态刷新,所以这种方法也是不可取的。

    后续跟客户沟通后,找到了另一种方法:不使用倒计时了,使用提示信息。当满足关闭当前窗口并跳回父窗口的条件时,弹出提示信息,让用户自己操作是否返回主页。代码如下:

    // 回到home页面,浏览器会拦截不是用户直接操作的跳转页面
    backHome() {this.$confirm('所有数据均以保存,是否返回主页?', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {// 回到父窗口home页面window.open(window.opener.location.href, window.opener.name);// 关闭当前浏览器window.close();}).catch(() => {window.open('about:blank');window.close();});
    },
    

    以上就是所有的内容了,如果有更好的方法,请多多留言!!!

http://www.dt0577.cn/news/41111.html

相关文章:

  • 深圳宝安医院的网站建设广州现在有什么病毒感染
  • 苏州外贸营销网站建设网络推广外包业务销售
  • 政府类网站的设计特点seo搜索引擎优化实训
  • 网站的竞价怎么做抖音矩阵排名软件seo
  • 长春做网站哪家好国内免费b2b网站大全
  • 网站同城在线哪里做手机优化助手
  • 江门网站制作计划竞价托管一般要多少钱
  • 网站建设xs029下载百度语音导航地图
  • 好的网站模板新网络营销
  • 公司做网站需准备资料指数基金怎么选
  • 坪山做网站的公司手机百度网盘下载慢怎么解决
  • 网站建设的界面f分百度关键词搜索引擎排名优化
  • 商务网站建设策划书新网站seo
  • 自己做网站需要买什么全网软文推广
  • 住房城乡建设厅网站准考证南宁百度seo排名优化软件
  • 巴顿品牌设计上首页的seo关键词优化
  • 深圳市建设管理委员会网站搜索引擎优化论文
  • 华强方特网站开发沈阳seo合作
  • 网站为何要屏蔽百度蜘蛛重庆seo按天收费
  • wordpress 音频播放seo网站优化做什么
  • 深圳龙华做网站公司上海建站seo
  • 找人做黑彩网站靠谱么个人网站制作多少钱
  • 网络广告发布的形式主要包括seo网站优化方案
  • 百度统计wordpress肇庆seo
  • 炽乐清网站建设怎么做百度网页推广
  • 淘宝美工做倒计时图片网站百度电脑版登录网站
  • ppt公司简介模板搜索引擎优化论文
  • wordpress图片盗链seo整站优化哪家好
  • 大连零基础网站建设教学电话口碑营销成功案例
  • 网站建设订单模板下载外贸seo公司