1***@qq.com
1***@qq.com
  • 发布:2019-07-17 14:38
  • 更新:2019-07-17 14:38
  • 阅读:2467

PC端web-view样式调节、全屏、刷新、内存释放(删除多余iframeDom)

分类:HTML5+

1.样式调节
当你使用web-view标签后会在页面生成一个iframe,我们主要是针对这个生成的iframe做样式调节,要注意的是你在引入web-view组件的vue文件中定义iframe是不会生效的,需要再项目根目录的app.vue 下定义才能生效。(如果项目中有多个模块需要引入样式不一致的iframe那就当我没写过这条~。~)

2.iframe全屏操作
全屏参考https://blog.csdn.net/IT_COOKIE_SAM/article/details/76944134,实现后全屏效果和你在浏览器按F11是一样的。这边注意全屏后要改变iframe中的
allowFullscreen = true才能生效

                        // 全屏  
            intoFull(el){  
                var rfs = el.requestFullScreen || el.webkitRequestFullScreen || el.mozRequestFullScreen || el.msRequestFullScreen,wscript;  
                if(typeof rfs != "undefined" && rfs) {    
                    rfs.call(el);    
                    return;    
                }  
                if(typeof window.ActiveXObject != "undefined") {    
                    wscript = new ActiveXObject("WScript.Shell");    
                    if(wscript) {    
                        wscript.SendKeys("{F11}");    
                    }    
                }  
            },  
            // 退出全屏  
            exitFullScreen(el) {    
                var el= document,cfs = el.cancelFullScreen || el.webkitCancelFullScreen || el.mozCancelFullScreen || el.exitFullScreen,wscript;    
                if (typeof cfs != "undefined" && cfs) {    
                    cfs.call(el);    
                    return;    
                }    
                if (typeof window.ActiveXObject != "undefined") {    
                    wscript = new ActiveXObject("WScript.Shell");    
                    if (wscript != null) {    
                        wscript.SendKeys("{F11}");      
                    }    
                }    
            },  
            // 触发全屏按钮事件  
            fullScreen(){  
                let iframeDom = document.getElementsByTagName("iframe")[0];  
                this.intoFull(iframeDom);  
                iframeDom.allowFullscreen = true  
            },

3.刷新iframe
刷新效果比较简单,直接获取页面上iframe DOM信息然后替换他的src属性(替换contentWindow.location.href也是可以的哦~)

let iframeDom = document.getElementsByTagName("iframe")[0];  
iframeDom.src="xxxxxxxxxxxx";

4.内存释放(删除多余iframeDom)
正如1中所提到的当你使用web-view标签后会在页面生成一个iframe,而你路由发生改变后(跳转页面等操作),生成的iframe是不会自动删除的,也就是说你在引入了web-view的页面不断进入退出会在你页面中生成无数个iframe,带来一系列问题(不知道是不是因为我用了自定义模板的原因,据观察页面跳转时uni-App只会刷新uni-app标签内的内容,可以它理解成route标签,而iframe是生成在body下的并不会被页面渲染到),下图是我进出4次页面后的效果:


解决方案是在在当前页面加载完成后通过this.$watch函数监听路由变化,当路由跳转时触发里面的函数遍历删除页面上的iframe节点,最后在注销路由监听(不注销监听的话watch会在全局监听你的路由触发事件)

// vue生命周期函数  
        mounted(){  
            this.unwatch = this.$watch('$route.path',()=>{  
                let iframeDom = document.getElementsByTagName("iframe");  
                if(iframeDom.length==0){  
                    return false;  
                }else{  
                    for(var i=0;i<iframeDom.length;i++){  
                        //释放iframe内存  
                        iframeDom[i].src = 'about:blank';   
                        try{   
                            iframeDom[i].contentWindow.document.write('');   
                            iframeDom[i].contentWindow.document.clear();   
                        }catch(e){}   
                        //把iframe从页面移除   
                        iframeDom[i].parentNode.removeChild(iframeDom[i]);   
                    }  
                }  
                // 注销路由监听  
                this.unwatch();  
            });  
        },

才疏学浅,希望对需要的人有所帮助。

1 关注 分享
2***@qq.com

要回复文章请先登录注册