以下是我开发时碰到一些小问题,如有错误欢迎指正,持续更新
- xml文件尽量以utf-8编码,gb2312有些字是存储不了的,如©,就算能存也需要转换,比较麻烦,utf-8也符合国际规范
- CSS中:hover这个伪类,如果放在:visited前面则会失效
- <a>标签如果没有href属性,所有对它的css的伪类如:hover均失效
- js文件中用document.wirte("<script language='javascript' src='" + file + "'></" + "script>"形式的引用,其file相对路径均为引用该js的html的路径。
如:a.htm 引用x\b.js,b.js引用x\c.js,则file应该为x\c.js而不是相对b.js的直接路径c.js,而css中的@import,url()引用不存在这个问题
- 在页面中,有时talbe的宽设置为100%右边也会留下一个滚动条的空白,请设置<body style="overflow:auto">
- 对于常用的图片不要用img标签,使用<span><a>并用css指定其背景和宽高,对于做动态的(移上去变背景),使用<a>最好,不需要额外编写代码,只要利用伪类:hover就好了,使用css好处是一次改变全部改变,这点可以很好的利用在换皮肤的应用中
- @font-face {
font-family:comic;
src:url(http://valid_url/some_font_file.eot);
}
定义一种在本地没有的字体名称,调用<span style="font-family:comic;font-size:18pt>aa</span> - 几个CSS
div { overflow: hidden;text-overflow:ellipsis; }
td { vertical-align : middle; }
要强制溢出发生并且应用 ellipsis 值,作者必须设置对象的 white-space 属性值为 nowrap 。
假如没有换行机会(例如,对象容器的宽度是狭窄的,而内有很长的没有合理断行的文本),没有应用 nowrap 也有可能溢出。
为了使 ellipsis 值被应用,此属性必须被设置到具有不可视区域的对象。最好的选择是设置 overflow 属性为 hidden - firefox的document.createElement不支持内容里有HTML标签,也不支持innerText,但是支持innerHTML,可以用innerHTML指定其内容
- .net控件里DropDownList在firefox下的宽度不着色,需要直接定义style='10px;'
- firefox中css的cursor不支持hand,使用pointer代替
- iframe里的滚动条需要在iframe标签里设置style='overflow:hidden',不能紧紧在body里设置
- 在onpropertychange事件时,注意使用event.propertyName对属性改变事件过滤,在设置本事件时,其实已经改变了onpropertychange这个属性,所以会自动的执行一次
- js5.6里的对XSL的支持版本较低,如document函数就不支持
- slice函数比直接循环获取数组片断慢
- nextSibling获得下一个对象时,需要注意,两个节点间不要有空格,否则很容易获取不到正确得对象,你将获得一个nodeName为#text的对象
- CreateTextFile在有中文时必须指定第三个参数为true,否则不能写入中文,表现为Write写时报错
- 保存中文文本时使用ADODB.stream,不使用fso,因为FSO不支持utf-8格式
- IE中尽量使用execScript代替eval,因为有时eval会失效
- 字符串中\结尾为换行字符
- JS里设置控件的属性,有几个特殊的,如:style要转换为style.cssText属性,class要转换为className属性
- 经常碰到脚本测试是正常的,但是复制到IDE里保存却不正常(莫名其妙的报错),则你可能要查查脚本文件和ASP,ASPX文件的编码是否一致(GB2312、UTF-8),可以使用记事本另存为一致的编码或者你也可以在调用脚本的时候指定其编码,如:<script language="javascript" src="a.js" charset="gb2312"></script>