HTC基础知识

2023-12-08 0 840

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>

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 htc HTC基础知识 https://www.u-9.cn/jiaoben/htc/145123.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务