45fan.com - 路饭网

搜索: 您的位置主页 > 网络频道 > 阅读资讯:关于HTC编程的一些基础知识教程

关于HTC编程的一些基础知识教程

2015-07-14 14:58:11 来源:www.45fan.com 【

关于HTC编程的一些基础知识教程

HTC是HTMLComponent的缩写,是IE5及后续版本浏览器所支持的客户端组件。据我个人理解,HTC就是一组以DHTML为基础封装了客户端行为的脚本,每HTC以*.htc的文件存储,一个HTC是一个客户端“类”。

对象

document在给定的浏览器窗口中表现HTML文档。

element返回一份主文档中连接行为的标签的参考。

PUBLIC:ATTACH绑定一个函数到一个事件上,因此每次事件发生在特殊对象上时函数会被调用。

PUBLIC:COMPONENT以HTC指明文件的内容。

PUBLIC:DEFAULTS设定一份HTC的默认属性。

PUBLIC:EVENT定义一个HTC的事件,使之暴露于包含该HTC的文档。

PUBLIC:METHOD定义一个HTC的方法,使之暴露于包含该HTC的文档。

PUBLIC:PROPERTY定义一个HTC的属性,使之暴露于包含该HTC的文档。

方法

createEventObject

创建一个事件对象,当需要传递事件附加信息给PUBLIC:EVENT元素的fire方法时使用。

事件

oncontentready

连接了行为的元素的内容完全被解析时发生。

oncontentsave

连接了一份元素行为的一个元素的内容被保存或复制前发生。

ondetach

从一个元素解除一份行为的连接前发生。

ondocumentready

当包含行为的文档完全被解析时发生。

示例
复制代码 代码如下:

<PUBLIC:COMPONENT>

<PUBLIC:PROPERTYNAME="grid"/><!--返回当前的Grid,通过该属性,可以访问当前Grid的相关信息-->

<!--和.Net中的DataColumn的定义类似-->

<PUBLIC:PROPERTYNAME="columnName"/><!--列名-->

<PUBLIC:PROPERTYNAME="dataType"/><!--数据类型,如System.String,和SmartGridColumn上的DataType的值保持一致-->

<PUBLIC:PROPERTYNAME="allowNull"/><!--是否允许为空-->

<PUBLIC:PROPERTYNAME="scale"/>

<PUBLIC:PROPERTYNAME="precision"/><!--精度,主要用于数字型-->

<PUBLIC:PROPERTYNAME="maxLength"/><!--最大长度,主要用于文本-->

<PUBLIC:PROPERTYNAME="extendedProperties"/><!--一般用xml串,因为在存储很多信息时,解析非常方便-->

<PUBLIC:METHODNAME="select"/><!--全眩由于参照编辑框由INPUT、IMG组成,所以需要改写(重载)select方法-->

<PUBLIC:METHODNAME="focus"><!--置焦点。由于参照编辑框由INPUT、IMG组成,所以需要改写(重载)focus方法-->

<PUBLIC:PROPERTYNAME="input"GET="getInput"/>

<PUBLIC:PROPERTYNAME="value"GET="getValue"PUT="setValue"/>

<PUBLIC:METHODNAME="cellDataCheck"/>

</PUBLIC:COMPONENT>

<scriptlanguage="javascript">

varid=null;

//参照一般有两个值,一个是显示的Text,一个是id。idColumn指明id的Grid列

varidColumn=null;

varrefUrl=null;

varrefIdColumn=null;

varrefNameColumn=null;

varextendedProp=element.extendedProperties;

if(extendedProp!=null&&typeof(extendedProp)!="undefined")

{

vardom=newActiveXObject("MSXML.DOMDocument");

dom.loadXML(extendedProp);

idColumn=dom.documentElement.getAttribute("idColumn");

varrefInfo=dom.documentElement.firstChild;

refIdColumn=refInfo.getAttribute("idColumn");

refNameColumn=refInfo.getAttribute("nameColumn");

refUrl=refInfo.getAttribute("url");

}

varbtn=element.getElementsByTagName("IMG")[0];

btn.onclick=btnClick;

functionbtnClick()

{

varret=window.showModalDialog(refUrl,self,'scrolling:no;resizable:no;status:no;dialogWidth:550px;dialogHeight:450px;center:1');

if(ret!=null)

{

varel=ret.documentElement.firstChild;

if(el!=null)

{

input.value=el.getAttribute(refNameColumn);

if(idColumn!=null&&idColumn!="")

{

id=el.getAttribute(refIdColumn);

grid.setCellValue(grid.row,idColumn,id);

}

}

}

//--------------------------------------------------------------

grid.setCellValue(grid.row,"num",100);//赋值示例

grid.setCellValue(grid.row,"price",10);//赋值示例

//-------------------------------------------------------------

}

varstatusText="";

varinput=element.getElementsByTagName("INPUT")[0];

input.onblur=inputOnBlur;

functioninputOnBlur()

{

grid.status=statusText;//可以通过grid.status来修改Grid状态条的状态。

}

functiongetInput()

{

returninput;

}

//该方法由SmartGrid在显示编辑器时调用。由于参照编辑器由INPUT、IMG等元素组成,所以需要告知SmartGrid在设置编辑器焦点时,应该让哪个元素获得焦点!

functionfocus()

{

input.focus();

}

//该方法由SmartGrid在对编辑器全选时调用。由于参照编辑器由INPUT、IMG等元素组成,所以需要告知SmartGrid在全选编辑器的内容时,应该怎样进行全选!

functionselect()

{

input.select();

}

functionsetValue(val)

{

input.value=val;

if(idColumn!=null)

{

varr=grid.row;

id=grid.getCellValue(r,idColumn);

}

}

functiongetValue()

{

returninput.value;

}

functioncellDataCheck(args)

{

return;

}

</script>

 

本文地址:http://www.45fan.com/a/question/14452.html
Tags: HTC 基础知识 HTMLComponent
编辑:路饭网
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部