Category ArchiveJavaScript/DOM/XML
HTML/XHTML/CSS & JavaScript/DOM/XML & 技术 06 Dec 2006 01:44 pm
offsetHeight在ie和ff下的差异
当你的html没设DTD时,设置一个div并包含一张图片,ie的offsetHeight会多出4个象素。
解决方法是去掉img标签后的换行.让
- </img>后紧跟</div>
或者使用js来判断浏览器。
当你设一div width=50px border=1px,ie的offsetHeight和clientHeight分别是50px和48px,ff是52px和50px
JavaScript/DOM/XML & 技术 05 Dec 2006 01:42 pm
JavaScript 中对像的 “foreach” 语法
- //变量声明,方法一:假如 Object 未被扩展
- var array = new Object();
- //变量声明,方法二:假如 Object 已被扩展
- var array;
- //赋值,以上两种方法均可
- array['something'] = 'yay';
- array['somethingelse'] = 'more';
- //循环
- for ( var keyVar in array ) {
- alert(array[keyVar]);
- }
注意 var keyVar ,不加var 为全局全量,可能引起冲突
HTML/XHTML/CSS & JavaScript/DOM/XML & 技术 05 Dec 2006 01:38 pm
scrollLeft,scrollWidth,clientWidth,offsetWidth到底指的哪到哪的距离
IE6.0、FF1.06+:
clientWidth = width + padding
clientHeight = height + padding
offsetWidth = width + padding + border
offsetHeight = height + padding + border
IE5.0/5.5:
clientWidth = width - border
clientHeight = height - border
offsetWidth = width
offsetHeight = height
(需要提一下:CSS中的margin属性,与clientWidth、offsetWidth、clientHeight、offsetHeight均无关)
JavaScript/DOM/XML & 技术 27 Nov 2006 01:37 pm
js删除dom结点时遇到的问题
当你使用for来循环node.length,并删除其中结点时会删不干净。
- for(var i=0;i var field=lista.childNodes.item(i);
- if (field.className == 'area')
- {
- alert('title'+field.title);
- lista.removeChild(field);
- }
- }
因为当你删除一个结点时,结点的索引会-1,所以lista.childNodes.length也会相应-1。
测试代码:
列出了NodeList 对象所提供的属性和方法:
| NodeList 属性 | 描述 | 范例 |
| length | 包含在节点集合中的节点个数 | NodeCount =Element.childNodes.length; |
| item(0-based-index)(default method) | 依所传入的索引值,传回你所要的节点,而索引值零(0)表第一个节点代 | SecondChild=Element.childNodes.item (1) ;or SecondChild=Element.childNodes (1); |
| reset () | 设定内部指针,指向节点集合中第一个节点位置之前,所以当下个nextNode 被呼叫时,将传回第一个节点 | Element.childNodes.reset (); |
| nextNode () | 传回节点集合中的下一个节点,是籍由内部指针的标记来达到 | Element.childNodes.reset ();FirstNode=Element.childNodes.nextNode (); |
JavaScript/DOM/XML & 技术 08 Oct 2006 01:25 pm
dom操作select,增加选项
- document.all("authorid").options.remove(0);
- document.all("authorid").options.add(new Option(name,value));
转
下面的例子给出了一个完整的演示。由于看例子比我解说更容易理解,所以我就废话少说,把代码贴出,希望对大家需要的网友有一点帮助。
First Sample:
All items will change After you Selected!
Second Sample:
You selected Item in Main Select will change the Sub select Content!
Main Select:
Sub Select:
JavaScript/DOM/XML & 技术 05 Oct 2005 01:10 pm
IE+JS: 上传之前检测图片文件大小
转自http://www.ugia.cn/?p=73
文件上传之前的检测,通常是通过文件名来判断文件类型是否合法,但是要想检测文件的大小很难办到,除非在本地或者使用控件。不过在IE下img有几个附加的属性,如:fileCreatedDate、fileModifiedDate、fileSize、fileUpdatedDate、filters,我们可以通过这些属性来获取图片文件的部分信息,如文件大小,我们用file表单同img标签结合,就能够在上传之前判断图片文件的大小是否合法了。
限制:
K
还有一个小小的发现就是,IE下动画的onload事件是在每次循环开始都触发,这样我们可以通过他来达到和js里setInterval()函数一样的效果,如:
loops: 0
<input type="file" name="file1" id="file1" size="40" onchange="changeSrc(this)"/>
<img src="about:blank" id="fileChecker" alt="test" height="18"/>
<
script type="text/javascript">var oFileChecker = document.getElementById("fileChecker");
function
changeSrc(filePicker){
oFileChecker.src = filePicker.value;
} oFileChecker.onreadystatechange = function ()
{
if (oFileChecker.readyState == "complete")
{
checkSize();
}
}
function
checkSize(){
var limit = document.getElementById("fileSizeLimit").value * 1024;
if (
oFileChecker.fileSize > limit){
alert("too large");
}
else
{
alert("ok");
}
}
第二个:
<
script type="text/javascript">var loops = 0;
document.getElementById("monkey").onload = function ()
{
document.getElementById("loopsNum").innerText= loops;
loops ++;
}
另外补充一些手册里的东西:
MAX_FILE_SIZE 隐藏字段(单位为字节)必须先于文件输入字段,其值为接收文件的最大尺寸。这是对浏览器的一个建议,PHP 也会检查此项。在浏览器端可以简单绕过此设置,因此不要指望用此特性来阻挡大文件。实际上,PHP 设置中的上传文件最大值是不会失效的。但是最好还是在表单中加上此项目,因为它可以避免用户在花时间等待上传大文件之后才发现文件过大上传失败的麻烦。
注意:本文所讨论的特性仅在IE下有效。
JavaScript/DOM/XML & 技术 05 Oct 2005 01:06 pm
bindows
通过 Bindows™,你可以开发Web页面中的全功能桌面应用程序,而无需任何插件。
Bindows™ 框架提供给你:
- 基于类的面向对象 API;
- 一个完整的窗口系统,带有一组广泛支持的窗体小部件,包括菜单、表单、表格、滑块、量表以及更多;
- 开发零接触 SOA 客户端应用程序的最好的工具包;
- 内置 XML,SOAP 和 XML-RPC 支持;
- 从单用户到企业级的支持。
“富”“瘦”兼备
Bindows 突破了你必须要在富(界面)和瘦(客户端)之间选择的典范。Bindows 应用程序可以如现代任何桌面应用程序一样华丽同时又极其瘦小(并且是零接触)。Bindows 应用程序是:
- 华丽的,可定制的,有着桌面般的 GUI 组件
- 运行于标准的浏览器中而无需任何安装的(零接触)
- 无需专门的客户端,运行时引擎,或者插件
无依赖性
Bindows 应用程序不依赖于:
- 服务器 —— 任何服务器(Java,.NET,PHP 等都可以与 Bindows 结合使用)
- 后端平台 —— 任何后端硬件和后端软件
- 操作系统 —— 客户端可以使用任何操作系统(只要它包含一个支持的浏览器)
- 语言 —— 所有的语言都支持。Bindows 支持 Unicode
- 浏览器 —— 大部分浏览器都支持(比如:Internet Explorer 5.5 及其更高版本,Mozilla 1.4 及其更高版本,Netscape 7.1 及其更高版本,Firefox,K-Meleon 和 Camino)
Bindows 软件开发工具包(SDK)
Bindows 是一个用来编写安全健壮的 Rich Internet Applications 的软件开发工具包(SDK)。Bindows 平台为瘦 Web 客户端提供了丰富的功能。Bindows 应用程序无需终端用户下载 —— 真正的零接触(不使用 Java、Flash 或者 ActiveX)。
要看 Bindows™ 所能创造的效果,可以看一下这些范例,或者试验一下这个论坛。
如果你希望学习更多关于如何构建 Bindows™ 应用程序的内容,可以查看文档部分。
XML 和 Web Services
Bindows 应用程序通过 XML 文档来定义,并且支持标准的 SOAP Web Services.
Bindows 开发环境
- 支持企业级项目
- 跨浏览器、跨平台支持
- 不依赖于服务器的构架
- 可以与新的和已存在的资源协同工作
- 有统一的开发方式
Rich Internet Applications (RIA)
Rich Internet Applications 将现代 PC 桌面程序般的界面与基于 Internet 的构架相结合,使得通过 Internet 浏览器访问到的程序拥有桌面软件一样的功能。RIA 允许 Web 站点在无需终端用户下载的情况下提供复杂的数据处理并有着快速的反应时间。
商业 2.0 杂志(2004 年 10 月)将 Rich Internet Applications 选为 2005 年被关注的十项技术之一。
bindows官方
http://www.bindows.net/
bindows论坛
http://www.bindows.net/webboard/
bindows中文
http://www.bindows.net.cn/
JavaScript/DOM/XML & 技术 04 Jan 2005 11:06 am
JavaScript图形库
JavaScript图形库
http://dev.csdn.net/Develop/article//28/28060.shtm
这位老外Walter Zorn的网址是http://www.walterzorn.com,很好的javascript的网站,很强的说。
这次用到的是WEB直接绘图功能,到这个地址下载
http://www.walterzorn.com/scripts/wz_jsgraphics.zip
