1 Css
1.1 选择器
* 通配符 * :: IE6不支持
* 类选择器 .class :: IE6元素的class不能超过2个
* 属性选择器 [att=value] [att] [att|=value] [att(^|$|~)=value] :: IE6不支持
* 关系选择器 E + F; E > F ; E ~ F :: IE6不支持
1.2 伪类
* :first-letter,:first-line,:visited,:link :: 都支持
* :hover :: IE6只支持A元素,IE7及FF支持A以外元素
* :before和:after :: IE7和firefox支持,好好利用可以实现很多不错的效果
1.3 !IMPORTANT
* 突破样式表属性>ID>双CLASS>单CLASS>元素,后者>前者的层叠顺序,不过IE6不支持
1.4 DocType
文档类型决定了IE的渲染模式,标准模式(standard)还是兼容模式(quirks),并且声明必须放在所有代码之前,包括注释。
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN”“">http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
查看详情Quirks模式与Standards模式
* 盒模型 标准模式,实际宽度=width+border-width+padding-width+margin-width 兼容模式下,实际宽度=width
* 水平居中 IE中,标准模式下可使用margin:0 auto水平居中。兼容模式下无效。
* 行内元素尺寸 标准模式下不能设置span等行内元素的width和height,兼容模式下可以。
* 不正确的语法 譬如未书写尺寸单位,大小写不正确,嵌套不正确等,兼容模式下尺寸采用默认单位px,其它的都尽量修正。标准模式下这条css规则无效。
* 相对高度 元素设定百分比高度时,需要父元素高度已指定,所以最好先指定html和body元素高度为100%
* IE7的新CSS特性 min/max-width/height,position:fixed,:hover,overflow:visible 等在兼容模式下会失效。
* 默认样式 FF下,在进入quirks模式后,会加载其目录下的res/quirk.css,设置一些其它的默认样式
1.5 属性
* Z-INDEX SELECT元素浮动在其它元素的上方,不能改变z-index,必要的时候采用js来控制select的显隐达到需要的效果 FLASH默认的wmode为window模式,浮动在其它html元素的上方,指定z-index不会改变这种情况。需要将wmode指定为 transparent或者opaque
o 元素级别层叠剖析
* CURSOR FF 不支持cursor:hand,使用cursor:pointor
* 列表取消缩进 IE margin:0;FF padding:0
* 自动折行
o DIV
-
.wrap1 {
-
word-break:break-all;
-
word-warp:warp;
-
over-flow:auto!important;
-
}
-
.wrap2 {
-
white-spacing:normal;
-
word-warp:warp;
-
over-flow:auto!important;
-
}
o TABLE
-
table{
-
table-layout:fixed;
-
}
* 固定宽度不折行
-
<td width="25%" nowrap><div>content</div></td>
* 空DIV仍占空间
-
.empty{
-
line-height:0%;
-
height:0px;
-
font-size:0pt;
-
}
1.6 滤镜(filter)
IE私有,效率也比较低,一般不建议使用。
* 透明
IE:
-
#id{ filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)}
FF:
1.7 行为(behavier)
在css中使用js, IE特有,借此可实现max-width,min-width等效果,不过效率比较低.同时这里也是可能存在XSS攻击的地方.
1.8 Bug
* 高度不适应 :: 内层设完margin或者padding后比外层高度还高。解决方案:在内层上下各加一个空div.
* 容器不扩展 :: 内存浮动后,外层缩成直线。解决方案:内存结束时清除浮动。
* margin加倍 :: 在IE 5.x、IE6中,为float的盒子指定margin时,左侧margin可能会变成两倍的宽度。通过改用padding或指定盒子为display:inline可以解决
* IE6 3px :: IE6中左浮动div右侧的文本和块与左div的距离会增加3px,解决方法给左侧的div增加margin-right:-3px;或者避免使文本直接与左div接触,同时右侧的块使用display:inline-block
* IE6捉迷藏 :: 一个浮动元素后而跟着一些非浮动元素,然后是一个清理元素,所有这些元素都包含在一个设置了背景颜色或图像的容器元素中。假如清理元素砬到了浮动元素,那么中间的非浮支元素看起来消失了,隐到了父元素的背景颜色或图像后面,只有在刷新页面时才重新出现。解决方案:去掉背景或者容器指定宽高,或者指定行高,或者将浮动元素和容器元素的position属性设置为relative也会减轻这个问题。
* IE6断头台 :: 当容器中左浮动对象右侧直接跟链接,并且链接的hover状态属性有变化的话,可能导致容器的高度重新计算,并切掉左浮动对象的部分内容。解决方案:浮动对象后面不直接跟非浮动对象,或者最后清除浮动。
1.9 css hack
* @import
-
@import ("notIE.css") screen;
* +_hack
-
#content {
-
width:500px;
-
+width:480px;
-
_width:490px:
-
}
* 条件注释
-
<!--[if lt IE 7]>
-
<link type="text/css" rel="stylesheet" href="cond.css" />
-
<![endif]-->
* 更多CSS HACK
2 Javascript
2.1 检测技术
* 对象检测
-
if (window.XMLRequest){
-
this.req = new XMLRequest;
-
}
-
else if (window.ActiveXObject){
-
this.req = new ActiveXObject("Micorsoft.XMLHTTP")
-
}
-
else {
-
throw new Error("Your browser doesn't support an XML HTTP Request.");
-
}
* 浏览器检测
-
var sUserAgent = navigator.userAgent;
-
var fAppVersion = parseFloat(navigator.appVersion);
-
var isOpera = sUserAgent.indexOf("Opera") > -1;
-
var isIE = sUserAgent.indexOf("compatible") > -1
-
&& sUserAgent.indexOf("MSIE") > -1
-
&& !isOpera;
-
var isMoz = sUserAgent.indexOf("Gecko") > -1
-
-
var isWin = (navigator.platform == "Win32") || (navigator.platform == "Windows");
-
var isMac = (navigator.platform == "Mac68K") || (navigator.platform == "MacPPC")
-
|| (navigator.platform == "Macintosh");
-
var isUnix = (navigator.platform == "X11") && !isWin && !isMac;
* 总结 :: 优先使用对象检测,尽量避免使用浏览器检测,这样能够适应更多的浏览器,而且还可以预防未来浏览器版本变化导致的一些不兼容问题。
2.2 Event
DOM标准中事件模型是先捕获再冒泡,IE中只有冒泡阶段。
事件获取
var evt = arguments[0] || window.evt;
添加/删除事件Handler
* IE :: attachEvent(window,‘onload’,handler)/distachEvent(window,‘onload’,handler)
* FF :: addEventListener(window,‘load’,handler,false)/removeEventListener(window,‘load’,handler,false)
SCRIPT标签
IE中script标签具有event和for属性 供事件绑定用 firefox 不支持
常用事件属性
IE FF 说明
cancelBubble stopProgation() 阻止事件起泡
srcElement target 事件对象
returnValue parentDefault() 阻止默认行为
中文输入法模式下的keyup事件
IE:触发keydown和keyup, 不触发keypress. 能够获得输入值。
Firefox:触发keydown和keypress, 不触发keyup. 输入值未能获得。在回车后会触发keyup, 可获得输入值。
Opera:keydown, keypress和keyup都不触发,输入值也未能获鼠标滚轮事件IE为mousewheel,FF为‘DOMMouseScroll’.滚轮的滚动距离IE为event.wheelDelta,FF为 event.detail,而且二者的方向相反,IE滚轮向下滚wheelDelta为负值
2.3 Dom
* FF的body在body标签没有被浏览器完全读入之前就存在,而IE则必须在body完全被读入之后才存在
* IE FF均支持parentNode,FF不支持parentElement
* FF不支持innerText,但有textContent
* DOM标准中Node无text和xml属性
* IE会忽略由空白和换行组成的部分,而FF将其作为文本节点
* IE有一些非标准的、Mozilla 不支持的内容操作方法,包括检索值、插入文本以及邻近某个节点插入元素,比如 getAdjacentElement 和 insertAdjacentHTML
* IE和DOM标准的文档片段处理方式不一样
* document.write(),如果写入的内容有脚本,FF会把字符串中的</script>解释成外层<script>的结束标签,需要将script标签拆分,document.write(“<script>alert(‘hello)</”+“script>”);
* Table操作ie不允许使用tr的innerHTML赋值,包括tbody
2.4 XML
* 空白 IE忽略 FF作为文本节点
* IE不支持节点类型的名称常量,如NODE.ELEMENT_NODE,只支持数字.可以自定义 var NODE = {ELEMENT_NODE:1}
* XMLRequest 参考
* XML解析器 参考
* XPath 参考
* XSLT转换 参考
2.5 Encode
* 浏览器中URL的编码特性
2.6 CompatMode
* 判别方法document.compatMode,页面未声明doctype时是backCompat,否则是CSS1Compat(IE8可能采用documentMode), FF不受CompatMode的影响,IE下可理解为IE5.5与IE6的区别
* 对JS的影响主要体现在clientWidth等属性上,关于对象使用document.body(简称b)还是document.documentElement(简称de)。
* 窗口尺寸 FF下窗口高度(不包含滚动条)为b.clientHeight,包含滚动条FF下面没有兼容模式下窗口高度(不包含滚动条)为b.clientHeight,包含滚动条IE下则为b.offsetHeight| 标准模式下不包含滚动条IE下为de.clientHeight,包含滚动条IE下为de.offsetHeight
* 内容尺寸 HTML高度FF下b.scrollHeight和de.scrollHeight,BODY的高度为b.offsetHeight 兼容模式下HTML高度IE为b.scrollHeight,Body无标准模式下HTML高度IE下为de.scrollHeight,Body高度为 b.clientHeight|b.scrollHeight|b.offsetHeight
* 滚动位置 FF下b.scrollLeft 兼容模式下b.scrollLeft 标准模式下de.scrollLeft
2.7 css
* height和width的单位 赋值时firefox需要加上单位px,IE可以不加
2.8 native
* 数组长度
[1,2,3,4,] IE下长度为5,firefox长度为4
* 对象
{key1:‘value1’,key2:‘value2’,}最后一个逗号IE下报错。
* 年份
2004年,而getYear()在FF下得到104,IE下则得到2004,建议使用getFullYear()代替
* for in
使用for in操作Dom元素时,IE会先列出内置的属性(没有function),再列出用户自定义的方法和属性,FF会先列出用户自定义的属性和方法,再列出内置的属性和方法
2.9 selector
* IE专有document.all(id), IE下id可直接获取元素, Firefox 都不支持; 应统一使用document.getElementById(id);
* IE下id可直接获取元素, 因此声明变量时一律加上var;
* IE下获取集合中子元素可使用[],(), Firefox不支持(); 应统一使用[]; document.form1.elements[name1]
* frames,forms,anchors等集合, IE下可通过id和name获取, firefox支持name获取, 可选方式, 使用name或者name和id保持一致
* 自定义属性IE下可通过elem.attr和getAttribute来访问, firefox支持后者,
* document.getElemsByName()IE下不能取得没有name属性的元素如div
2.10 窗口
* 窗口位置
o IE window.screenLeft,window.screenTop
o FF window.screenX windwo.screenY
* 窗口大小
o IE 未提供
o FF window.outerWidth window.outerHeight
* 视口大小 :: 显示HTML页的大小
o IE document.body.offsetWidth|document.body.offsetHeight
o FF window.innerWidth|window.innerHeight
2.11 大小写
IE 对于部分属性会忽略大小写,但FF不会 比如screen.availWidth
2.12 页面加载
页面加载的过程有两个事件,页面完全加载的window.onload,可理解为页面下载完成。另一个是dom准备完成事件,这时图片等可能尚未下载完。如果需要尽早的执行js,可以利用以下方式,创建domReady方法
-
function _fi(){if(arguments.callee.dn)return;arguments.callee.dn=true;if(_timer)clearInterval(_timer);for(var i=0;i<onloadList.length;i++){onloadList[i].call(window)}};
-
if(document.addEventListener){document.addEventListener("DOMContentLoaded",_fi,false);}
-
-
-
-
-
if (/KHTML|WebKit/i.test(navigator.userAgent)){var _timer=setInterval(function(){if(/loaded|complete/.test(document.readyState)){_fi();}},10);}
-
window.onload=_fi;
-
window.onloadList=[];
-
var domReady=function(fn){onloadList.push(fn);}
mooltools内置了domready事件
-
window.addEvent('domready', function(){
-
alert('the dom is ready');
-
});
2.13 剪贴板操作
-
function copyToClipboard(txt) {
-
if(window.clipboardData) {
-
window.clipboardData.clearData();
-
window.clipboardData.setData("Text", txt);
-
} else if(navigator.userAgent.indexOf("Opera") != -1) {
-
window.location = txt;
-
} else if (window.netscape) {
-
try {
-
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
-
} catch (e) {
-
alert("被浏览器拒绝!\n请在浏览器地址栏输入'about:config'并回车\n然后将'signed.applets.codebase_principal_support'设置为'true'");
-
}
-
var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard);
-
if (!clip)
-
return;
-
var trans = Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable);
-
if (!trans)
-
return;
-
trans.addDataFlavor('text/unicode');
-
var str = new Object();
-
var len = new Object();
-
var str = Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString);
-
var copytext = txt;
-
str.data = copytext;
-
trans.setTransferData("text/unicode",str,copytext.length*2);
-
var clipid = Components.interfaces.nsIClipboard;
-
if (!clip)
-
return false;
-
clip.setData(trans,null,clipid.kGlobalClipboard);
-
alert("复制成功!")
-
}
-
}
2.14 加入收藏夹
* IE :: window.external.AddFavorite(sURL, sTitle);
* FF :: window.sidebar.addPanel(sTitle, sURL, “”);
2.15 IE7的变化
* 打开的窗口无法从子窗口直接关闭,
-
window.opener = null;
-
window.open("",'_self');
-
window.close();
* 支持原生的XMLHTTP
* 支持postion:fixed 非常好的一个定位属性(需要指定DocType为标准模式),使得元素相对于浏览器定位,固定元素在左上角、右下角之类的非常简单。 标准模式下IE6也可通过以下方式模拟实现
-
<!--[if IE 6]>
-
<style type="text/css">
-
html{overflow:hidden;}
-
body{height:100%;overflow:auto;}
-
#fixed{position:absolute;right:17px;}
-
</style>
-
<![endif]-->
2.16 firefox 3的变化
firefox 3.0起支持使用模式对话框
2.17 其它
3 html
3.1 标签封闭
* 标签尽量封闭,即使不是xhtml,未封闭的标签对于浮动或者绝对定位的对象造成不可预期的位置错乱
* div等本应包含内容的标签置空时,也应当使用<div></div>,而不能写成<div />,<a>元素没封闭的话甚至可能影响到js的执行
3.2 空标签
* <td></td>中如果没有内容会导致边框不显示
* <li></li>中没有内容ff下不解析
* <a name=‘here’></a>空标签 IE6可能无法跳转。
3.3 Flash
* 使用embed元素,很多地方一些css的使用会受到较大限制,建议都采用object标签
-
<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000">
-
<param name="movie" value="Sample.swf" />
-
-
<param name="quality" value="high" />
-
<param name="wmode" value="transparent" />
-
<param name="flashvars" value="key=value" />
-
-
</object>
* flash 参数的传递 参数中的特殊字符需要转码,如&应转为%26,参考URL Encoding: Reading special characters
3.4 技巧
* Anchor标签执行Js写法, 避免页面跳转或者滚动等
-
<a href="#this" onclick="fun()" >text</a>
-
<a href="javascript:void(0)" onclick="fun()" >text</a>
-
<a href="#" onclick="javascript:fun();return false">text</a>
2,3不能加target=_blank属性
* 给legend标签设置宽度 firefox不支持直接设置legend宽度, 可以通过在 legend 标签内添加一个标签如span,并给标签设定所需要的宽度,此宽度的单位不可为百分比(%):
3.5 动态改变script的src属性
FF下不可以直接改变已有的script标签的src属性,ie可以。要兼容两者,可以动态的创建script元素
-
-
function changeScript(id,src) {
-
var newScript = document.createElement('script');
-
var oldScript = document.getElementById(id);
-
newScript.type = "text/javascript";
-
newScript.src = src;
-
newScript.id = id;
-
document.getElementsByTagName('body')[0].replaceChild(newScript,oldScript);
-
}
3.6 属性
* html中没有转义字符,属性中使用引号时需注意改成"
* FF不支持图片和链接的alt属性,改用title,IE和FF都支持
3.7 问题
* IE6不支持png的半透明效果
3.8 FOCUS 推行web标准需要注意的问题
* 超版页头的内容应当置于<doctyp><html><body>之下,执行正确的嵌套
* 已有内容的包含问题。
* 盒模型
* A和Div等元素应当完整的的封闭,即使是空标签,<a name=’#this’></a> <div class=‘clear’></div>
* center等标签推荐尽量不要使用,改用margin:0 auto;
* 宽高等应当加上单位px等
* table和form等的嵌套问题。
* 垂直居中的问题
分享到:
相关推荐
4. **浏览器兼容性**:前端开发者需要了解不同浏览器对HTML、CSS和JavaScript的支持情况,解决跨浏览器兼容性问题。可能的考题可能涉及IE与现代浏览器的差异,以及如何使用polyfill或条件注释来处理兼容性问题。 5....
5. **浏览器兼容性**:前端开发者需要了解不同浏览器对HTML、CSS和JavaScript的支持情况,能够编写跨浏览器的代码。 6. **前端框架与库**:如React、Vue、Angular等,它们简化了前端开发流程,提高效率。考试可能...
8. **浏览器兼容性**:了解不同浏览器对Web标准的支持程度,以及如何使用polyfill解决兼容性问题。 9. **ES6及后续版本的新特性**:包括箭头函数、模板字符串、Promise、Async/Await、模块导入导出等新特性的理解和...
JavaScript,作为前端开发的主要语言,其规范主要关注代码的可读性和跨浏览器兼容性。ESLint是一种常用的JavaScript代码检查工具,可以帮助开发者遵循一定的规范,比如使用严格模式,避免使用with语句,以及正确处理...
题目可能涉及HTML、CSS、JavaScript等基础知识,例如DOM操作、布局模式(如流式布局、网格布局、Flexbox和Grid)、浏览器兼容性问题、事件处理、数据类型和运算符等。 2. 某些题目可能涉及到前端框架的应用,如...
- 页面需兼容多种浏览器和分辨率,确保广泛适用性。 - 内容丰富度是吸引用户的关键,提供有价值的信息。 - 浏览速度要快,提高用户满意度。 - 技术含量体现在动静态元素的平衡,提升用户体验。 3. **多媒体技术...
- **设计技术**:使用HTML5、CSS3、JavaScript等工具,实现跨浏览器兼容性,保证不同分辨率下的页面一致性。 - **可用性和可及性**:创建易于导航的网站,考虑不同设备和人群的需求,提高可及性,如对视障人士的...
使用这类方法虽然可以达到背景音乐的效果,但要注意这并非HTML的标准做法,可能会导致兼容性问题或在某些浏览器中不起作用。 此外,HTML中的body元素还包含了topmargin和leftmargin属性,这些属性能够控制页面内容...
维护线上平台的功能完整性和浏览器兼容性。 - **设计组(美工)**:负责网站的视觉设计和美化工作。 - **岗位职责**: 1. 设计并优化公司网站的页面; 2. 制作各类专题模板; 3. 设计网站活动的宣传广告和标语...
- 兼容性优良:代码需考虑多种浏览器的兼容性,确保在主流浏览器中都能正常运行。 - 优化性能:代码简洁高效,减少服务器负载,提升页面加载速度。 3. **规范细则**: - **文件命名规则**: - 使用小写字母、...
4. 兼容性测试:测试软件在不同平台、浏览器、设备上的兼容性。 5. 压力测试:模拟超出正常范围的负载,检查软件的稳定性。 6. 回归测试:当代码修改后,重新执行受影响的测试用例,确保改动未引入新问题。 7. 用户...
- **浏览器**:支持Internet Explorer 6.0或IE 7.0版本,以满足网页端操作的需求。 - **数据库支持**:兼容Microsoft SQL Server 2000 SP4、Microsoft SQL Server 2005、Oracle 9i、Oracle 10g等多种数据库系统,...
4. 适应性:确保在不同浏览器和设备上的兼容性。 5. 用户体验:页面加载速度、布局美观、交互流畅。 通过这个上机试题,学生不仅能检验自己的技术掌握程度,也能了解到实际工作中网页设计与制作的规范和标准,为...
- 答题过程中无法访问互联网,采用“服务器-浏览器”方式发放试题、回收选手答案。 - **竞赛用时**: - 预赛时长:5小时 - 决赛时长:5小时 #### 四、试题形式与内容 - **单片机设计与开发项目**: - 客观题...
- **原因**:虽然更换浏览器可以在一定程度上提高安全性,但许多应用程序和网站与IE浏览器兼容,强制更换可能会影响正常工作,并不能完全防止病毒感染。 #### 七、ISO27001控制措施的范围 - **知识点概述**:ISO...
- **兼容性**:支持多种操作系统和浏览器。 ##### 2.4 系统功能介绍 - **企业门户**:提供个性化的信息展示平台,集成企业内部资源。 - **信息发布**:支持文档、公告等多类型信息的发布与管理。 - **个人工作台**...
4. **优秀的兼容性**:确保代码在主流浏览器中的稳定运行。 5. **良好的页面性能**:优化加载速度和渲染效率。 6. **简洁有序的代码**:代码易于理解和维护。 7. **减少服务器负载**:通过合理的资源管理减轻服务器...
"Thuan Phat Hung - Paper Chemistry Solutions-crx插件"是一款专为处理化学产品包装和运输问题设计的浏览器扩展程序。这款插件旨在为用户提供一个高效、安全的平台,以解决化学产品在包装和运输过程中的各种挑战。...