2015第7周二技术学习

IE下使用jQuery重置iframe地址时内存泄露问题解决办法

页面中有个iframe:

?


1

2

 <iframe src=‘a.html‘></iframe>

<button>测试IFRAME泄露</button>

其中a.html内容如下:

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>Insert title here</title>

<script type="text/javascript" src="jquery/jquery.min.js"></script>

<style>

.hack{

 /* 1.所有浏览器都有效 */

 background-color:green;

 /* 2.IE8~IE10,Opera有效,但是Opera兼容性可以不考虑 */

 background-color:blue\0;

 /* 3.IE9~IE10有效,与2组合,在2中先写针对IE8的,在此条中针对IE9|IE10 */

 background-color:red\9\0;

 /* 4.IE7有效,与23组合能区分出IE7/IE8/(IE9|IE10) */

 +background-color:yellow;

}

/* 针对IE10+ */

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {  

 .hack{

  background-color:pink;

 

}

 

</style>

</head>

<body>

后缀"\9"  IE6/IE7/IE8/IE9/IE10都生效

后缀"\0"  IE8/IE9/IE10都生效,是IE8/9/10的hack

后缀"\9\0"  只对IE9/IE10生效,是IE9/10的hack

前缀"*"  对IE7有效

前缀"+"  对IE7有效

选择器前缀 @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none)

   针对IE10有效

<input type=‘text‘ value=‘中文‘></input>

<div class=‘hack‘ style="width:100px;

 height:100px;"></div>

<div id="1" style="padding:5px;position:relative;background-color:green;margin:10px;border:20px solid red;width:100%;height:200px;">

</div>

<div id="2"></div>

<span>SPAN</span>

</body>

</html>

b.html内容如下:

?


1

2

3

4

5

6

7

8

9

10

11

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>Insert title here</title>

<script type="text/javascript" src="jquery/jquery.min.js"></script>

</head>

<body>

<span>SPAN</span>

</body>

</html>

网上有传,如下写法可降低内存泄露:

?


1

2

3

4

5

6

7

8

 var frameDom = $(‘iframe:eq(0)‘)[0];

 var frameWin = frameDom.contentWindow;

 try

      frameWin.document.write(‘‘); 

      frameWin.document.clear(); 

 }catch(e){}; 

 frameDom.src = ‘b.html‘;

那么效果怎样呢?

写法一:直接设置URL

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

var flag = true;

 var frameDom = $(‘iframe:eq(0)‘)[0];

 $(‘button‘).on(‘click‘,function(){

  if(flag){

   var frameDom = $(‘iframe:eq(0)‘)[0];

   var frameWin = frameDom.contentWindow;

   /*

   try{ 

    frameWin.document.write(‘‘); 

    frameWin.document.clear(); 

      }catch(e){}; 

      */

      frameDom.src = ‘b.html‘;

   flag = false;

  }else{

   var frameDom = $(‘iframe:eq(0)‘)[0];

   var frameWin = frameDom.contentWindow;

   /*

   try{ 

    frameWin.document.write(‘‘); 

    frameWin.document.clear(); 

      }catch(e){}; 

      */

      frameDom.src = ‘a.html‘;

   flag = true;

  }

  //$(‘#console‘).append(flag ? ‘切换到a.html‘:‘切换到b.html‘);

 });

使用sIEve测试:每切换一次,#leaks增加28左右。

写法二:按网传写法

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

<script>

 var flag = true;

 var frameDom = $(‘iframe:eq(0)‘)[0];

 $(‘button‘).on(‘click‘,function(){

  if(flag){

       var frameDom = $(‘iframe:eq(0)‘)[0];

       var frameWin = frameDom.contentWindow;

       try

           frameWin.document.write(‘‘); 

           frameWin.document.clear(); 

       }catch(e){}; 

       frameDom.src = ‘b.html‘;

       flag = false;

  }else{

       var frameDom = $(‘iframe:eq(0)‘)[0];

       var frameWin = frameDom.contentWindow;

       try

          frameWin.document.write(‘‘); 

          frameWin.document.clear(); 

       }catch(e){}; 

       frameDom.src = ‘a.html‘;

       flag = true;

  }

  //$(‘#console‘).append(flag ? ‘切换到a.html‘:‘切换到b.html‘);

 });

</script>

使用sIEve测试:每切换一次,#leaks增加28左右。与写法一并没有什么差别

写法三:

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

var flag = true;

 var frameDom = $(‘iframe:eq(0)‘)[0];

 $(‘button‘).on(‘click‘,function(){

  if(flag){

   /*

   try{ 

    frameDom.contentWindow.document.write(‘‘); 

    frameDom.contentWindow.document.clear(); 

    frameDom.contentWindow.close(); 

      }catch(e){};

      */

      $(‘iframe:eq(0)‘).remove();

      $(‘body‘).append("<iframe src=‘b.html‘></iframe>");

   flag = false;

  }else{

   /*

   try{ 

    frameDom.contentWindow.document.write(‘‘); 

    frameDom.contentWindow.document.clear(); 

    frameDom.contentWindow.close(); 

      }catch(e){};

      */

      $(‘iframe:eq(0)‘).remove();

      $(‘body‘).append("<iframe src=‘a.html‘></iframe>");

   flag = true;

  }

 });

使用sIEve测试:#leaks平均增加值为 3,与前两种相差巨大

写法四:注意到,写法三中注释了一段代码,去掉注释会怎样?

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

var flag = true;

 var frameDom = $(‘iframe:eq(0)‘)[0];

 $(‘button‘).on(‘click‘,function(){

  if(flag){

   

   try

    frameDom.contentWindow.document.write(‘‘); 

    frameDom.contentWindow.document.clear(); 

    frameDom.contentWindow.close(); 

      }catch(e){};

      

      $(‘iframe:eq(0)‘).remove();

      $(‘body‘).append("<iframe src=‘b.html‘></iframe>");

   flag = false;

  }else{

   

   try

    frameDom.contentWindow.document.write(‘‘); 

    frameDom.contentWindow.document.clear(); 

    frameDom.contentWindow.close(); 

      }catch(e){};

      

      $(‘iframe:eq(0)‘).remove();

      $(‘body‘).append("<iframe src=‘a.html‘></iframe>");

   flag = true;

  }

 });

此写法与写法3并没有明显差别,每次切换#leaks仍然增加3左右

因此可以得出结论,最好的解决重置iframe地址内存泄露办法就是 把它干掉,再添加一个!

来源: <http://my.oschina.net/lldy/blog/375626>

什么是无编程?

  • 这是项目的的一个核心,不需要直接编程就能实现做出各种精美,复杂的应用,而且是几乎跨是有平台的,目前来说可以直接通过网页在线看,也可以生成APK、IPA应用文件在移动端安装,也可以在桌面通过exe加壳运行,反正就是实现的代码只有一份,可以跑基于WebView的任意平台。

如何实现无编程?

  • 简单的来说用户可以通过一套软件,可以把具体的抽象设计给控件化,有点类似.net的控件一样,自动生成代码。

如何实现跨平台?

  • 跨平台很简单就是通过web App技术就可以

其实最重要的2个方向我们已经确定了,那么我们怎么才能实现无编程快速应用开发?

  • 我们只需要把用户想要操作的的行为告诉前端代码就就可以了,这里其实就是一个编程的传递了,传统的开发都是我们开发者引导用户行为,那么现在的的方式就是让制作者引导,而不是开发者处理了,我们开发者要做的一个事件就是,如何让编辑者的逻辑设计能够最终实现
  • 用户的抽象行为是可以用数据描述的,我们可以把用户的行为写到数据库里面,然后前端代码通过读取数据库来获取这个行为,正好HTML5的Web Sql Database就能完全胜任这个工作的,那么我们现在整的设计原型就出来了:通过PPT抽象用户的设计写入到数据库,前端通过读取数据库还原用户的设计

    来源: <http://www.cnblogs.com/aaronjs/p/4255232.html#_h1_3>

来自为知笔记(Wiz)

时间: 2024-08-25 03:21:30

2015第7周二技术学习的相关文章

2015第40周二Node学习

node历史 今天看cnode开源项目用了io.js,在查这个项目时发现这篇文章node历史,node.js和io.js关系谈到Node.js的由来,不可避免要聊到它的创始人Ryan Dahl.在2009年时,服务端JavaScript迎来了它的拐点,因为Ryan Dahl带来了Node.js,在那之后Node.js将服务端JavaScript带入了新的境地,大量的JavaScript在GitHub上被贡献出来,大量的JavaScript模块出现,出现了真正的繁荣.Node.js创始人Ryan

我的2015技术学习流水账

我的2015技术学习流水账 2015年马上就要过去了,匆匆忙忙地又是一年.回头总结整理,发现这一年还挺充实的.在正常上班工作之余,学习到了不少新东西,不禁感到很欣慰!一个多月前就开始写,终于赶在2016年来临之前写完了这篇文章-- 关于本文,尽管叫做流水账,但是出于程序员条理性的"强迫症",还是进行系统分类,分类方法参照Thoughtworks技术雷达的Tecniques.Languages & Frameworks.Tools.Platforms,将其中的Tecniques改

技术学习规划

技术学习规划: ? 2015年 2016年 2017年 基础理论 TCP/IP协议: ? ? ? ? ? ? ? ? ? ? ? ?<TCP/IP详解卷I>(第1遍) ? ? ? ? ? ? ? ? ? ? ? ?<图解TCP/IP>. 数据结构与算法: ? ? ? ? ? ? ? ? ? ? ? ? ?<算法> TCP/IP协议: ? ? ? ? ?<TCP/IP详解卷I>(第2遍) ? ? ? ? ? HTTP协议:<图解HTTP> 数据结构

VR/AR 技术学习园地

~~~ 建構中/請稍待 ~~~ 欢迎光临 VR(含AR) 技术学习园地 来欣赏VR技术的魅力...           [起步] 以<魚目混珠>俚語來比喻VR.AR與MR的區別 魚目混珠意味著:珍珠是真實(True Reality,簡稱TR),而魚目虛假的(Virtual).模仿真實(Reality)的,合稱為虛擬真實(Virtual Reality),又稱虛擬現實,簡稱VR. 所以,VR開發就是:做出幾可亂真的魚目. AR是替珍珠化妝.打扮,讓珍珠(真實)更加光彩,耀眼奪目. MR則是魚目混

2015级计算机科学与技术软件工程(西北师范大学)助教总结

2015级计算机科学与技术软件工程(西北师范大学)助教总结 18年软件工程课程助教总结 非常有幸在上学期由代老师的推荐担任18年软件工程课程助教.在代老师.邹欣老师.周筠老师和郑蕊老师的监督和帮助下,我完成了助教工作.从开始的对助教工作的一知半解到最后的得心应手,都离不开老师和同学们的支持和配合. 虽然这是我第二次担任本科生助教,但是这次的助教工作才正式登堂入室.通过本次工作,我基本上搭建起来软件工程助教相关工作的框架,使我对助教工作有了深刻的理解,这对于下学期指导和帮助师弟师妹助教工作有巨大益

EMV技术学习和研究(转)

刚开始学习EMV&PBOC,磕磕碰碰,感谢xuture的<EMV技术学习和研究>给了很大帮助,让我少走了很多弯路,也感谢广俊.surge.艾零.小SO.Spinach.龙行天下的帮助,尤其要感谢广俊!!! 分享也收藏<EMV技术学习和研究>链接: EMV技术学习和研究(一)开篇 EMV技术学习和研究(二)应用选择 EMV技术学习和研究(三)应用初始化&&读应用数据 EMV技术学习和研究(四)脱机数据认证之SDA EMV技术学习和研究(五)脱机数据认证之DDA

Linux技术学习要点,您掌握了吗---初学者必看

Linux技术学习要点,您掌握了吗---初学者必看 1.如何做好嵌入式Linux学习前的准备? 要成为一名合格的嵌入式Linux工程师,就需要系统的学习软.硬件相关领域内的知识,需要在最开始就掌握开发的规范和原则,养成良好的工作习惯.为了确保学习的效果,信盈达安排的整个课程体系是非常集中.高效的,这就要求准备参加嵌入式Linux就业课程学习的同学要调整好自己的时间,务必要确保在4个多月的学习时间内能够高度集中精力.兄弟连Linux培训. 在整个集中学习过程中,既要保证课上认真听讲.实战演练的时间

Java多线程技术学习笔记(二)

目录: 线程间的通信示例 等待唤醒机制 等待唤醒机制的优化 线程间通信经典问题:多生产者多消费者问题 多生产多消费问题的解决 JDK1.5之后的新加锁方式 多生产多消费问题的新解决办法 sleep和wait的区别 停止线程的方式 守护线程 线程的其他知识点 一.线程间的通信示例 返目录回 多个线程在处理同一资源,任务却不同. 假设有一堆货物,有一辆车把这批货物往仓库里面运,另外一辆车把前一辆车运进仓库的货物往外面运.这里货物就是同一资源,但是两辆车的任务却不同,一个是往里运,一个是往外运. 下面

Java反射技术学习总结

-------<a href="http://www.itheima.com/"">android培训</a>.<a href="http://www.itheima.com/" ">java培训</a>期待与您交流!---------- Java反射技术就是将java中的类的各个组成部分反射出来变为java中相应的数据类型获得. Java同样将类中的各个组成部分进行封装,变为一个个Java类. C