﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-Just For Love-随笔分类-Web</title><link>http://www.blogjava.net/esprit/category/12902.html</link><description>AZA~AZA~FIGHTING......</description><language>zh-cn</language><lastBuildDate>Thu, 01 Mar 2007 11:22:25 GMT</lastBuildDate><pubDate>Thu, 01 Mar 2007 11:22:25 GMT</pubDate><ttl>60</ttl><item><title>[转]IE与Firefox对CSS解析的区别</title><link>http://www.blogjava.net/esprit/archive/2006/09/21/71099.html</link><dc:creator>esprit</dc:creator><author>esprit</author><pubDate>Thu, 21 Sep 2006 06:49:00 GMT</pubDate><guid>http://www.blogjava.net/esprit/archive/2006/09/21/71099.html</guid><wfw:comment>http://www.blogjava.net/esprit/comments/71099.html</wfw:comment><comments>http://www.blogjava.net/esprit/archive/2006/09/21/71099.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/esprit/comments/commentRss/71099.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/esprit/services/trackbacks/71099.html</trackback:ping><description><![CDATA[
		<p>1、IE与Firefox下对CSS解析的区别,这是我在使用中的一些经验，拿出来和大家分享，希望大家继续</p>
		<p>
				<strong>对高度的解析</strong>
		</p>
		<p>IE：将根据内容的高度变化，包括未定义高度的图片内容，即使定义了高度，当内容超过高度时，将使用实际高度。</p>
		<p>Firefox：没有定义高度时，如果内容中包括了图片内容，MF的高度解析是根据印刷标准，这样就会造成和实际内容高度不符合的情况；当定义了高度,但是内容超过高度时，内容会超出定义的高度，但是区域使用的样式不会变化，造成样式错位。</p>
		<p>结论：大家在可以确定内容高度的情况下最好定义高度，如果真的没有办法定义高度，最好不用使用边框样式，否则样式肯定会出现混乱！</p>
		<p>
				<strong>img对象alt和title的解析<br /></strong>alt：当照片不存在或者load错误时的提示；<br />title：照片的tip说明。<br />在IE中如果没有定义title，alt也可以作为img的tip使用，但是在MF中，两者完全按照标准中的定义使用</p>
		<p>结论：大家在定义img对象时，最后将alt和title对象都写全，保证在各种浏览器中都能正常使用</p>
		<p>
				<strong>其他的细节差别<br /></strong>当你在写css的时候，特别是用float: left（或right）排列一窜图片时，会发现在firefox里面正常而IE里面有问题。无论你用margin:0,还是border: 0来约束，都无济于事。</p>
		<p>其实这里还有另外一个问题，就是IE对于空格的处理，firefox是忽略的而IE对于块与块之间的空格是处理的。也就是说一个div结束后要紧接着一个div写，中间不要有回车或者空格。不然也许会有问题，比如3px的偏差，而且这个原因很难发现。</p>
		<p>非常不走运的是我又碰到了这样的问题，多个img标签连着，然后定义的float: left，希望这些图片可以连起来。但是结果在firefox里面正常而IE里面显示的每个img都相隔了3px。我把标签之间的空格都删除都没有作用。</p>
		<p>后来的解决方法是在img外面套li，并且对li定义margin: 0，这样就解决了IE和firefox的显示偏差。IE对于一些模型的解释会产生很多错误问题，只有多多尝试才能发现原因。</p>
		<p>
				<strong>2、嵌套DIV:父DIV的高度不能根据子DIV自动变化的解决方案</strong>
				<br />&lt;div id="parent"&gt;<br />&lt;div id="content"&gt; &lt;/div&gt;<br />&lt;/div&gt;</p>
		<p>当Content内容多时，即使parent设置了高度100%或auto,在不同浏览器下还是不能完好的自动伸展。 解决方案</p>
		<p>&lt;div id="parent"&gt;<br />&lt;div id="content"&gt;&lt;/div&gt;<br />&lt;div style="font: 0px/0px sans-serif;clear: both;display: block"&gt; &lt;/div&gt;<br />&lt;/div&gt;</p>
		<p>在层的最下方产生一个高度为1的空格，可解除这个问题</p>
		<p>
				<strong>3、CSS DIV 学习笔记</strong>
				<br />一、基本上每个区块的div 都要有自己的id，杜绝不同功能的区块用同一个id/class</p>
		<p>二、每个稍大的区块div 后面都跟一个&lt;!– /id –&gt;标记开始、结束</p>
		<p>三、隐藏文字的又一种方法 TEXT-INDENT: -9999px; LINE-HEIGHT: 0</p>
		<p>四、巧妙地处理并列的两列:<br />1)<br />右列为P, width=44.5%, float=left<br />左列为P.first, border-right: #a7a7a7 1px solid, width=45%<br />2)<br />右列#right, margin-left:50%<br />左列#left, float=left,width=50% border-right:#a7a7a7 1px solid</p>
		<p>以上两种方法关键点在于选择其中一个为float=left</p>
		<p>五、随机的切换图片：<br />#random {<br />BACKGROUND: url(/rotate.php);<br />}<br />这个方法很巧妙。</p>
		<p>4、关于div的高度自适应<br />　
　今天小尿让我帮他的页子解决一个问题，就是div的高度自适应，也就是在一个父级div中嵌套一左一右两个子div，右边的子div内容可无限扩展，而
可以使得父级div的高度能被无限拉长，用一般的布局方法，在IE中可以正确浏览，在Mozilla中父级div的高度就固定在10px左右，无法自适应
高度，height:auto也不行，怎么办呢。网上参考到一篇资料，要实现自适应高度，div层必须具有float属性，于是我开始动手试验，
float:left的话，div就跑到页面最左边去了，这好办，我在它的外面再套一层div，把位置定好，那么里面的就算float:left也不会被
移动位置了。</p>
		<p>xhtml:<br />===============</p>
		<p>&lt;div id="container_father"&gt;<br /> &lt;div id="container"&gt;<br />   &lt;div id="panel"&gt; test&lt;br /&gt;<br />    test&lt;br /&gt;<br />    test&lt;br /&gt;<br />     &lt;!– id="panel" –&gt;<br />   &lt;/div&gt;<br />   &lt;div id="sidebar"&gt;<br />    &lt;ul&gt;<br />      &lt;li class="current"&gt;预安装检查&lt;/li&gt;<br />      &lt;li&gt;阅读 PFC 授权协议&lt;/li&gt;<br />      &lt;li&gt;初始化数据库&lt;/li&gt;<br />      &lt;li&gt;完成安装&lt;/li&gt;<br />     &lt;/ul&gt;<br />     &lt;!– id="sidebar" –&gt;<br />   &lt;/div&gt;<br />   &lt;!– id="container" –&gt;<br /> &lt;/div&gt;<br />&lt;/div&gt;</p>
		<p>CSS<br />=================<br />#container_father {<br />margin-left: auto;<br />margin-right: auto;<br />padding: 0px;<br />width: 750px;<br />}</p>
		<p>#container {<br />  width: 750px;<br />  border: 1px solid #cccccc;<br />  padding: 8px;<br />  margin: 0px;<br />  background-color: #F1F3F5;<br />  float: left;<br />}</p>
		<p>FRom: http://ulean.zg163.net/</p>
		<p>
				<strong>5、  深入标准  ~  The IE Doubled Float-Margin Bug(IE双倍浮动边界Bug)</strong>
				<br />什么发生故障？</p>
		<p>一
段无错的代码把一个居左浮动(float:left)的元素放置进一个容器盒(box)，并在浮动元素上使用了左边界(margin-left)来令它和
容器的左边产生一段距离。看起来相当的简单，对吗？但直至它被在IE/Win中浏览为止，在浏览器中居左浮动元素的边界长度被神秘地翻了一倍！</p>
		<p>情况应该如何？</p>
		<p>下面的图释展示了一个简单的div(茶色的盒子)包含着一个居左浮动的div(绿色的盒子)。浮动元素有一个100px的左边界，使容器盒与它的左边缘之间产生了一个100px的间隙。到现在为止，一直都还不错。</p>
		<p>.floatbox {<br />float: left;<br />width: 150px;<br />height: 150px;<br />margin: 5px 0 5px 100px;<br />/*This last value applies the 100px left margin */<br />}</p>
		<p>陈旧的IE“双倍占据”</p>
		<p>原样的相同代码被在IE/Win中浏览时以些微不同的方式显示，下面的图释展示了IE/Win在布局上所做的。</p>
		<p>这为什么会发生？别问这种傻问题！这就是IE，记得吗？符合标准只是理想的状况，不指望实现，这个简单的事实正验证了。</p>
		<p>重点</p>
		<p>这个Bug仅当浮动边界和浮动元素的方向相同时出现在浮动元素和容器盒的内边缘之间，在这之后的任意有着相似边界的浮动元素不会呈现双倍边界。只有特定的浮动行的第一个浮动元素会遭遇这个Bug。像居左的情况一样，双倍边界同样神秘地显示在居右的相同方式。</p>
		<p>最后，修复办法！</p>
		<p>直
到现在(04年1月)这个Bug一直被认为是无法修复的，通常用来替代错误的边界的控制方法如：一个不可视浮动元素的左边距，连同一个内嵌的盒子一起，可
视的盒子装在不可视浮动元素里；或者使用技巧仅对IE/Win设定边界的1/2值。这办法生效了，但是是混乱的而且搞糟了干净的源代码。不过现在全部结束
了。</p>
		<p>Steve Clason发现了一个修复办法，描述在他的Guest Demo里，修复了双倍边界和围绕文字缩进Bug。这是一个经典的IE的Bug修复办法，使用一个属性来修复影响不相关属性的Bug。</p>
		<p>现在如何来做？</p>
		<p>研究它，简单地将{display: inline;}设置给浮动元素就是全部所需做的！是的，听起来太简单了，不是吗？不过这是真的，仅仅一个display的"inline"声明已经能够胜任了。</p>
		<p>熟悉规则的人知道浮动元素自动设置为"block"元素，而不管他们之前是什么。就如Steve从W3C里指出：</p>
		<p>9.5.1 Positioning the float: the ‘float’ property</p>
		<p>"This property specifies whether a box should float to the left,
right, or not at all. It may be set for elements that generate boxes
that are not absolutely positioned. The values of this property have
the following meanings:</p>
		<p>left<br />The element generates a block box that is floated to the
left. Content flows on the right side of the box, starting at the top
(subject to the ‘clear’ property). The ‘display’ is ignored, unless it
has the value ‘none’.</p>
		<p>right<br />Same as ‘left’, but content flows on the left side of the box, starting at the top.</p>
		<p>none<br />The box is not floated. "</p>
		<p>这 说明浮动元素上的{display:
inline;}会被忽略，事实上所有的浏览器没有呈现任何改变，包括IE。但是，它不知何故让IE停止将浮动元素的边界翻倍。因而，这个修复办法可以被
直接应用，而没有任何繁琐的隐藏方法。如果将来的一款浏览器决定对这个修复办法抱恙，只要把这个修复装入IE独用的Tan Hack里，细节如同IE
Three Pixel Text-Jog Demo。</p>
		<p>下面是两个使用了前面相同代码的生动演示，第一个照常显示了IE的Bug，下一个对浮动元素使用了"inline"修复。<br />.floatbox {<br />float: left;<br />width: 150px;<br />height: 150px;<br />margin: 5px 0 5px 100px;<br />display: inline;<br />}</p>
		<p>
				<font color="#ff0000">Update (20060828)：<br /></font>
				<strong>6、空&lt;li&gt;&lt;/li&gt;解析问题</strong>。</p>
		<p>在FF下空&lt;li&gt;&lt;/li&gt;是不被解析的，也就是说，&lt;li&gt;标签所带的css样式是不被解释的。但是在IE下空&lt;li&gt;&lt;/li&gt;是一样会被解析的。<br />例如我定义如下Css:<br />#sidebar ul li {<br />　　list-style-type: none;<br />　　list-style-image: none;<br />　　margin-bottom: 15px;<br />}</p>
		<p>而我的sidebar使用了一个空的 &lt;li&gt;&lt;/li&gt; 。那么在FF下不被解析，而在IE下会出现15px的空白。</p>
<img src ="http://www.blogjava.net/esprit/aggbug/71099.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/esprit/" target="_blank">esprit</a> 2006-09-21 14:49 <a href="http://www.blogjava.net/esprit/archive/2006/09/21/71099.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>收藏帖 常用的一些javascript小技巧</title><link>http://www.blogjava.net/esprit/archive/2006/07/08/57300.html</link><dc:creator>esprit</dc:creator><author>esprit</author><pubDate>Sat, 08 Jul 2006 15:53:00 GMT</pubDate><guid>http://www.blogjava.net/esprit/archive/2006/07/08/57300.html</guid><wfw:comment>http://www.blogjava.net/esprit/comments/57300.html</wfw:comment><comments>http://www.blogjava.net/esprit/archive/2006/07/08/57300.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/esprit/comments/commentRss/57300.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/esprit/services/trackbacks/57300.html</trackback:ping><description><![CDATA[事件源对象 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />event.srcElement.tagName <br />event.srcElement.type <br /><br /></td></tr></tbody></table><br />捕获释放 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />event.srcElement.setCapture();  <br />event.srcElement.releaseCapture();<br /><br /></td></tr></tbody></table><br />事件按键<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />event.keyCode <br />event.shiftKey <br />event.altKey <br />event.ctrlKey <br /><br /></td></tr></tbody></table><br />事件返回值<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />event.returnValue <br /><br /></td></tr></tbody></table><br />鼠标位置 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />event.x <br />event.y <br /><br /></td></tr></tbody></table><br />窗体活动元素<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />document.activeElement <br /><br /></td></tr></tbody></table><br />绑定事件<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />document.captureEvents(Event.KEYDOWN); <br /><br /></td></tr></tbody></table><br />访问窗体元素 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.all("txt").focus(); <br />document.all("txt").select(); <br /><br /></td></tr></tbody></table><br />窗体命令 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.execCommand <br /><br /></td></tr></tbody></table><br />窗体COOKIE <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.cookie <br /><br /></td></tr></tbody></table><br />菜单事件 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.oncontextmenu<br /><br /></td></tr></tbody></table> <br />创建元素<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.createElement("SPAN"); <br /><br /></td></tr></tbody></table><br />根据鼠标获得元素：<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />document.elementFromPoint(event.x,event.y).tagName=="TD <br />document.elementFromPoint(event.x,event.y).appendChild(ms)<br /><br /></td></tr></tbody></table><br />窗体图片<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />document.images[索引] <br /><br /></td></tr></tbody></table><br />窗体事件绑定 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.onmousedown=scrollwindow; <br /><br /></td></tr></tbody></table><br />元素 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.窗体.elements[索引]<br /><br /></td></tr></tbody></table> <br /><br />对象绑定事件 <br /><br /><br />插件数目<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />navigator.plugins <br /><br /></td></tr></tbody></table><br />取变量类型<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />typeof($js_libpath) == "undefined" <br /><br /></td></tr></tbody></table><br />下拉框<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />下拉框.options[索引] <br />下拉框.options.length <br /><br /></td></tr></tbody></table><br />查找对象 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.getElementsByName("r1"); <br />document.getElementById(id); <br /><br /></td></tr></tbody></table><br /><br />定时 <br /><br /><br />UNCODE编码 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />escape() ,unescape <br /><br /></td></tr></tbody></table><br />父对象 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />obj.parentElement(dhtml) <br />obj.parentNode(dom)<br /><br /></td></tr></tbody></table><br />交换表的行<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />TableID.moveRow(2,1) <br /><br /></td></tr></tbody></table><br />替换CSS <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.all.csss.href = "a.css"; <br /><br /></td></tr></tbody></table><br />并排显示 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />display:inline<br /><br /></td></tr></tbody></table> <br />隐藏焦点 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />hidefocus=true <br /><br /></td></tr></tbody></table><br />根据宽度换行<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />style="word-break:break-all"<br /><br /></td></tr></tbody></table> <br />自动刷新 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />&lt;meta HTTP-EQUIV="refresh" CONTENT="8;URL=http://c98.yeah.net"&gt;<br /><br /></td></tr></tbody></table> <br />简单邮件<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;a href="mailto:aaa@bbb.com?subject=ccc&amp;body=xxxyyy"&gt; <br /><br /></td></tr></tbody></table><br />快速转到位置 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />obj.scrollIntoView(true)<br /><br /></td></tr></tbody></table> <br />锚<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;a name="first"&gt; <br />&lt;a href="#first"&gt;anchors&lt;/a&gt; <br /><br /></td></tr></tbody></table><br />网页传递参数<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />location.search();<br /><br /></td></tr></tbody></table><br />可编辑<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />obj.contenteditable=true <br /><br /></td></tr></tbody></table><br />执行菜单命令<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />obj.execCommand <br /><br /></td></tr></tbody></table><br />双字节字符 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />/[^\x00-\xff]/ <br /><br /></td></tr></tbody></table><br />汉字 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />/[\u4e00-\u9fa5]/ <br /><br /></td></tr></tbody></table><br />让英文字符串超出表格宽度自动换行<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />word-wrap: break-word; word-break: break-all; <br /><br /></td></tr></tbody></table><br />透明背景<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;IFRAME src="1.htm" width=300 height=180 allowtransparency&gt;&lt;/iframe&gt; <br /><br /></td></tr></tbody></table><br />获得style内容<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />obj.style.cssText <br /><br /></td></tr></tbody></table><br />HTML标签<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />document.documentElement.innerHTML <br /><br /></td></tr></tbody></table><br />第一个style标签<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />document.styleSheets[0] <br /><br /></td></tr></tbody></table><br />style标签里的第一个样式<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />document.styleSheets[0].rules[0] <br /><br /></td></tr></tbody></table><br />防止点击空链接时，页面往往重置到页首端。<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;a href="javascript:function()"&gt;word&lt;/a&gt; <br /><br /></td></tr></tbody></table><br />上一网页源<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />asp: <br />request.servervariables("HTTP_REFERER") <br />javascript: <br />document.referrer <br /><br /></td></tr></tbody></table><br />释放内存<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />CollectGarbage();<br /><br /></td></tr></tbody></table><br />禁止右键 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.oncontextmenu = function() { return false;} <br /><br /></td></tr></tbody></table><br />禁止保存 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />&lt;noscript&gt;&lt;iframe src="*.htm"&gt;&lt;/iframe&gt;&lt;/noscript&gt;<br /><br /></td></tr></tbody></table><br />禁止选取<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />&lt;body oncontextmenu="return false" ondragstart="return false" onselectstart ="return false" onselect="document.selection.empty()" oncopy="document.selection.empty()" onbeforecopy="return false"onmouseup="document.selection.empty()&gt; <br /><br /></td></tr></tbody></table><br />禁止粘贴<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;input type=text onpaste="return false"&gt; <br /><br /></td></tr></tbody></table><br />地址栏图标 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />&lt;link rel="Shortcut Icon" href="favicon.ico"&gt;<br /><br />favicon.ico 名字最好不变16*16的16色,放虚拟目录根目录下 <br />收藏栏图标 <br /><br />&lt;link rel="Bookmark" href="favicon.ico"&gt; <br /><br /></td></tr></tbody></table><br /><br />查看源码<br /><br /><br />关闭输入法<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;input style="ime-mode:disabled"&gt; <br /><br /></td></tr></tbody></table><br />自动全选<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;input type=text name=text1 value="123" onfocus="this.select()"&gt; <br /><br /></td></tr></tbody></table><br />ENTER键可以让光标移到下一个输入框<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;input onkeydown="if(event.keyCode==13)event.keyCode=9"&gt;<br /><br /></td></tr></tbody></table><br />文本框的默认值<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;input type=text value="123" onfocus="alert(this.defaultValue)"&gt; <br /><br /></td></tr></tbody></table><br />title换行<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />obj.title = "123&amp;#13sdfs&amp;#32" <br /><br /></td></tr></tbody></table><br />获得时间所代表的微秒 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />var n1 = new Date("2004-10-10".replace(/-/g, "\/")).getTime() <br /><br /></td></tr></tbody></table><br />窗口是否关闭 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />win.closed <br /><br /></td></tr></tbody></table><br />checkbox扁平<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;input type=checkbox style="position: absolute; clip:rect(5px 15px 15px 5px)"&gt; <br /><br /></td></tr></tbody></table><br />获取选中内容 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />document.selection.createRange().duplicate().text<br /><br /></td></tr></tbody></table><br />自动完成功能<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />&lt;input  type=text  autocomplete=on&gt;打开该功能  <br />&lt;input  type=text  autocomplete=off&gt;关闭该功能 <br /><br /></td></tr></tbody></table><br />窗口最大化 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />&lt;body onload="window.resizeTo(window.screen.width - 4,window.screen.height-50);window.moveTo(-4,-4)"&gt; <br /><br /></td></tr></tbody></table><br />无关闭按钮IE<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />window.open("aa.htm", "meizz", "fullscreen=7"); <br /><br /></td></tr></tbody></table><br />统一编码/解码<br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"> <br />alert(decodeURIComponent(encodeURIComponent("http://你好.com?as= hehe"))) <br />encodeURIComponent对":"、"/"、";" 和 "?"也编码 <br /><br /></td></tr></tbody></table><br /><br />表格行指示<br /><br /><br />//各种尺寸 <br /><br /><table cellspacing="1" width="100%" bgcolor="#cccccc" border="0"><tbody><tr><td bgcolor="#efefef"><br />s  +=  "\r\n网页可见区域宽："+  document.body.clientWidth;   <br />s  +=  "\r\n网页可见区域高："+  document.body.clientHeight;   <br />s  +=  "\r\n网页可见区域高："+  document.body.offsetWeight  +"  (包括边线的宽)";   <br />s  +=  "\r\n网页可见区域高："+  document.body.offsetHeight  +"  (包括边线的宽)";   <br />s  +=  "\r\n网页正文全文宽："+  document.body.scrollWidth;   <br />s  +=  "\r\n网页正文全文高："+  document.body.scrollHeight;   <br />s  +=  "\r\n网页被卷去的高："+  document.body.scrollTop;   <br />s  +=  "\r\n网页被卷去的左："+  document.body.scrollLeft;   <br />s  +=  "\r\n网页正文部分上："+  window.screenTop;   <br />s  +=  "\r\n网页正文部分左："+  window.screenLeft;   <br />s  +=  "\r\n屏幕分辨率的高："+  window.screen.height;   <br />s  +=  "\r\n屏幕分辨率的宽："+  window.screen.width;   <br />s  +=  "\r\n屏幕可用工作区高度："+  window.screen.availHeight;   <br />s  +=  "\r\n屏幕可用工作区宽度："+  window.screen.availWidth; <br /><br /></td></tr></tbody></table><br /><img src ="http://www.blogjava.net/esprit/aggbug/57300.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/esprit/" target="_blank">esprit</a> 2006-07-08 23:53 <a href="http://www.blogjava.net/esprit/archive/2006/07/08/57300.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>[转]Javascript的IE和Firefox兼容性汇编</title><link>http://www.blogjava.net/esprit/archive/2006/07/08/57298.html</link><dc:creator>esprit</dc:creator><author>esprit</author><pubDate>Sat, 08 Jul 2006 15:50:00 GMT</pubDate><guid>http://www.blogjava.net/esprit/archive/2006/07/08/57298.html</guid><wfw:comment>http://www.blogjava.net/esprit/comments/57298.html</wfw:comment><comments>http://www.blogjava.net/esprit/archive/2006/07/08/57298.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/esprit/comments/commentRss/57298.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/esprit/services/trackbacks/57298.html</trackback:ping><description><![CDATA[以下以 IE 代替 Internet Explorer，以 MF 代替 Mozzila Firefox<br /><br /><b>1. document.form.item 问题</b><br />(1)现有问题：<br />现有代码中存在许多 document.formName.item("itemName") 这样的语句，不能在 MF 下运行<br />(2)解决方法：<br />改用 document.formName.elements["elementName"]<br />(3)其它<br />参见 2<br /><br /><b>2. 集合类对象问题</b><br />(1)现有问题：<br />现有代码中许多集合类对象取用时使用 ()，IE 能接受，MF 不能。<br />(2)解决方法：<br />改用 [] 作为下标运算。如：document.forms("formName") 改为 document.forms["formName"]。<br />又如：document.getElementsByName("inputName")(1) 改为 document.getElementsByName("inputName")[1]<br /><br /><b>3. window.event</b><br />(1)现有问题：<br />使用 window.event 无法在 MF 上运行<br />(2)解决方法：<br />MF 的 event 只能在事件发生的现场使用，此问题暂无法解决。可以这样变通：<br />原代码(可在IE中运行)：<br />&lt;input type="button" name="someButton" value="提交" onclick="javascript:gotoSubmit()"/&gt;<br />...<br />&lt;script language="javascript"&gt;<br />function gotoSubmit() {<br />...<br />alert(window.event); // use window.event<br />...<br />}<br />&lt;/script&gt;<br /><br />新代码(可在IE和MF中运行)：<br />&lt;input type="button" name="someButton" value="提交" onclick="javascript:gotoSubmit(event)"/&gt;<br />...<br />&lt;script language="javascript"&gt;<br />function gotoSubmit(evt) {<br />evt = evt ? evt : (window.event ? window.event : null);<br />...<br />alert(evt); // use evt<br />...<br />}<br />&lt;/script&gt;<br />此外，如果新代码中第一行不改，与老代码一样的话(即 gotoSubmit 调用没有给参数)，则仍然只能在IE中运行，但不会出错。所以，这种方案 tpl 部分仍与老代码兼容。<br /><br /><b>4. HTML 对象的 id 作为对象名的问题</b><br />(1)现有问题<br />在 IE 中，HTML 对象的 ID 可以作为 document 的下属对象变量名直接使用。在 MF 中不能。<br />(2)解决方法<br />用 getElementById("idName") 代替 idName 作为对象变量使用。<br /><br /><b>5. 用idName字符串取得对象的问题</b><br />(1)现有问题<br />在IE中，利用 eval(idName) 可以取得 id 为 idName 的 HTML 对象，在MF 中不能。<br />(2)解决方法<br />用 getElementById(idName) 代替 eval(idName)。<br /><br /><b>6. 变量名与某 HTML 对象 id 相同的问题</b><br />(1)现有问题<br />在 MF 中，因为对象 id 不作为 HTML 对象的名称，所以可以使用与 HTML 对象 id 相同的变量名，IE 中不能。<br />(2)解决方法<br />在声明变量时，一律加上 var ，以避免歧义，这样在 IE 中亦可正常运行。<br />此外，最好不要取与 HTML 对象 id 相同的变量名，以减少错误。<br />(3)其它<br />参见 问题4<br /><br /><b>7. event.x 与 event.y 问题</b><br />(1)现有问题<br />在IE 中，event 对象有 x, y 属性，MF中没有。<br />(2)解决方法<br />在MF中，与event.x 等效的是 event.pageX。但event.pageX IE中没有。<br />故采用 event.clientX 代替 event.x。在IE 中也有这个变量。<br />event.clientX 与 event.pageX 有微妙的差别（当整个页面有滚动条的时候），不过大多数时候是等效的。<br /><br />如果要完全一样，可以稍麻烦些：<br />mX = event.x ? event.x : event.pageX;<br />然后用 mX 代替 event.x<br />(3)其它<br />event.layerX 在 IE 与 MF 中都有，具体意义有无差别尚未试验。<br /><br /><b>8. 关于frame</b><br />(1)现有问题<br />在 IE中 可以用window.testFrame取得该frame，mf中不行<br />(2)解决方法<br />在frame的使用方面mf和ie的最主要的区别是：<br />如果在frame标签中书写了以下属性：<br />&lt;frame src="xx.htm" id="frameId" name="frameName" /&gt;<br />那么ie可以通过id或者name访问这个frame对应的window对象<br />而mf只可以通过name来访问这个frame对应的window对象<br />例如如果上述frame标签写在最上层的window里面的htm里面，那么可以这样访问<br />ie： window.top.frameId或者window.top.frameName来访问这个window对象<br />mf： 只能这样window.top.frameName来访问这个window对象<br /><br />另外，在mf和ie中都可以使用window.top.document.getElementById("frameId")来访问frame标签<br />并且可以通过window.top.document.getElementById("testFrame").src = ‘xx.htm’来切换frame的内容<br />也都可以通过window.top.frameName.location = ‘xx.htm’来切换frame的内容<br />关于frame和window的描述可以参见bbs的‘window与frame’文章<br />以及/test/js/test_frame/目录下面的测试<br />----adun 2004.12.09修改<br /><br /><b>9. 在mf中，自己定义的属性必须getAttribute()取得</b><br /><br /><b>10.在mf中没有 parentElement parement.children 而用parentNode parentNode.childNodes</b><br />childNodes的下标的含义在IE和MF中不同，MF使用DOM规范，childNodes中会插入空白文本节点。<br />一般可以通过node.getElementsByTagName()来回避这个问题。<br />当html中节点缺失时，IE和MF对parentNode的解释不同，例如<br />&lt;form&gt;<br />&lt;table&gt;<br />&lt;input/&gt;<br />&lt;/table&gt;<br />&lt;/form&gt;<br />MF中input.parentNode的值为form, 而IE中input.parentNode的值为空节点<br /><br />MF中节点没有removeNode方法，必须使用如下方法 node.parentNode.removeChild(node)<br /><br /><b>11.const 问题</b><br />(1)现有问题:<br />在 IE 中不能使用 const 关键字。如 const constVar = 32; 在IE中这是语法错误。<br />(2)解决方法:<br />不使用 const ，以 var 代替。<br /><br /><b>12. body 对象</b><br />MF的body在body标签没有被浏览器完全读入之前就存在，而IE则必须在body完全被读入之后才存在<br /><br /><b>13. url encoding</b><br />在js中如果书写url就直接写&amp;不要写&amp;amp;例如var url = ‘xx.jsp?objectName=xx&amp;amp;objectEvent=xxx’;<br />frm.action = url那么很有可能url不会被正常显示以至于参数没有正确的传到服务器<br />一般会服务器报错参数没有找到<br />当然如果是在tpl中例外，因为tpl中符合xml规范，要求&amp;书写为&amp;amp;<br />一般MF无法识别js中的&amp;amp;<br /><br /><b>14. nodeName 和 tagName 问题</b><br />(1)现有问题：<br />在MF中，所有节点均有 nodeName 值，但 textNode 没有 tagName 值。在 IE 中，nodeName 的使用好象<br />有问题（具体情况没有测试，但我的IE已经死了好几次）。<br />(2)解决方法：<br />使用 tagName，但应检测其是否为空。<br /><br /><b>15. 元素属性</b><br />IE下 input.type属性为只读，但是MF下可以修改<br /><img src ="http://www.blogjava.net/esprit/aggbug/57298.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/esprit/" target="_blank">esprit</a> 2006-07-08 23:50 <a href="http://www.blogjava.net/esprit/archive/2006/07/08/57298.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>