经验几则
(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )
以下是我开发时碰到的问题以及心得经验,花了些时间调试,贴出来避免大家少走弯路,如有错误欢迎指正,
持续更新ing
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='width:10px;'
firefox中css的cursor不支持hand,使用pointer代替
iframe里的滚动条需要在iframe标签里设置style='overflow:hidden',不能仅仅在body里设置,在firefox会
有问题
在onpropertychange事件时,注意使用event.propertyName对属性改变事件过滤,在设置本事件时,其实已经
改变了onpropertychange这个属性,所以会自动的执行一次
js5.6里的对XSL的支持版本较低,如document函数就不支持
slice函数比直接循环获取数组片断慢
nextSibling获得下一个对象时,需要注意,两个节点间不要有空格,否则很容易获取不到正确得对象
CreateTextFile在有中文时必须指定第三个参数为true,否则不能写入中文,表现为Write写时报错
保存中文文本时使用ADODB.stream,不使用fso,因为FSO不支持utf-8格式
持续更新ing
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='width:10px;'
firefox中css的cursor不支持hand,使用pointer代替
iframe里的滚动条需要在iframe标签里设置style='overflow:hidden',不能仅仅在body里设置,在firefox会
有问题
在onpropertychange事件时,注意使用event.propertyName对属性改变事件过滤,在设置本事件时,其实已经
改变了onpropertychange这个属性,所以会自动的执行一次
js5.6里的对XSL的支持版本较低,如document函数就不支持
slice函数比直接循环获取数组片断慢
nextSibling获得下一个对象时,需要注意,两个节点间不要有空格,否则很容易获取不到正确得对象
CreateTextFile在有中文时必须指定第三个参数为true,否则不能写入中文,表现为Write写时报错
保存中文文本时使用ADODB.stream,不使用fso,因为FSO不支持utf-8格式
下一篇:由给定的字符串生成关键字