htc基础知识
来源: 阅读:780 次 日期:2016-06-15 10:37:55
温馨提示: 小编为您整理了“htc基础知识”,方便广大网友查阅!

htc是html component的缩写,是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:property name=grid/><!--返回当前的grid,通过该属性,可以访问当前grid的相关信息-->

<!--和.net中的datacolumn的定义类似-->

<public:property name=columnname/> <!--列名-->

<public:property name=datatype/><!--数据类型,如system.string,和smartgridcolumn上的datatype的值保持一致-->

<public:property name=allownull/><!--是否允许为空-->

<public:property name=scale/>

<public:property name=precision/><!--精度,主要用于数字型-->

<public:property name=maxlength/><!--最大长度,主要用于文本-->

<public:property name=extendedproperties/><!--一般用xml串,因为在存储很多信息时,解析非常方便-->

<public:method name=select/><!--全选。由于参照编辑框由input、img组成,所以需要改写(重载)select方法-->

<public:method name=focus><!--置焦点。由于参照编辑框由input、img组成,所以需要改写(重载)focus方法-->

<public:property name=input get=getinput/>

<public:property name=value get=getvalue put=setvalue/>

<public:method name=celldatacheck/>

</public:component>

<script language=javascript>

var id = null;

//参照一般有两个值,一个是显示的text,一个是id。idcolumn指明id的grid列

var idcolumn = null;

var refurl = null;

var refidcolumn = null;

var refnamecolumn = null;

var extendedprop = element.extendedproperties;

if(extendedprop!= null && typeof(extendedprop) != undefined)

{

var dom = new activexobject(msxml.domdocument);

dom.loadxml(extendedprop);

idcolumn = dom.documentelement.getattribute(idcolumn);

var refinfo = dom.documentelement.firstchild;

refidcolumn = refinfo.getattribute(idcolumn);

refnamecolumn = refinfo.getattribute(namecolumn);

refurl = refinfo.getattribute(url);

}

var btn = element.getelementsbytagname(img)[0];

btn.onclick = btnclick;

function btnclick()

{

var ret = window.showmodaldialog(refurl,self,'scrolling:no;resizable:no;status:no;dialogwidth:550px;dialogheight:450px;center:1');

if(ret != null)

{

var el = 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); //赋值示例

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

}

var statustext = ;

var input = element.getelementsbytagname(input)[0];

input.onblur = inputonblur;

function inputonblur()

{

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

}

function getinput()

{

return input;

}

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

function focus()

{

input.focus();

}

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

function select()

{

input.select();

}

function setvalue(val)

{

input.value = val;

if(idcolumn != null)

{

var r = grid.row;

id = grid.getcellvalue(r,idcolumn);

}

}

function getvalue()

{

return input.value ;

}

function celldatacheck(args)

{

return ;

}

</script>

更多信息请查看脚本栏目
手机网站地址:htc基础知识
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map