HTC基础

news/2024/11/23 12:59:20/
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 >
 

http://www.ppmy.cn/news/115636.html

相关文章

htc g1 android4.0,都以为HTC G1是世界第一部安卓手机?其实不是!

原标题&#xff1a;都以为HTC G1是世界第一部安卓手机&#xff1f;其实不是&#xff01; G1由HTC制造&#xff0c;采用528MHz单核处理器、3.2英寸显示屏以及不带闪光灯的320万像素摄像头……听起来是不是非常寒碜&#xff1f;但6年前&#xff0c;它被公认为是iPhone的主要对手之…

HTC FOCUS3在PC端串流FOHEART H1数据手套(手柄)

本教程介绍使用FOHEART H1数据手套与HTC手柄驱动VR中的虚拟手运动&#xff0c;实现手部的追踪及定位。 本教程内容与之前使用腕带定位&#xff08;HTC FOCUS3在PC端串流FOHEART H1数据手套&#xff08;腕带&#xff09;&#xff09;不同&#xff0c;这次我们使用头显中自带的…

HTC VIVE装置故障排除方法

头戴显示器状态灯号与相关疑难解答 头戴显示器左侧灯号&#xff0c;代表显示器的运作状态 1. 【绿灯】运作正常 2. 【绿灯】但显示器内没有延伸屏幕 – 代表屏幕分辨率错误  请至&#xff08;控制面板 > 显示 > 屏幕分辨率&#xff09;  …

关于HTC

在微软IE 5.0版本的浏览器发布以前&#xff0c;网页编程中面对的最大挑战就是不能轻易地创建组件&#xff0c;以达到代码重用和多页面共享的目的。这个问题一直困扰着DHTML&#xff08;动态 HTML&#xff09;的网页编程者。他们只能不断地重复书写HTML、CSS和javascript的代码&…

ISTJ型人格的性格缺陷和心理问题分析

ISTJ是指内向、感觉、思维、判断的人格类型。他们通常非常可靠、坚定、严谨&#xff0c;善于制定计划并按照计划行事。 然而&#xff0c;ISTJ型人格也有一些性格缺陷和心理健康问题需要注意。 ISTJ型人格的性格缺陷 1.死板和过于保守&#xff1a; ISTJ型人格通常非常善于遵…

htcvr设备计算机配置,【HTC-VIVE】02-设备的安装与配置(上)

(113) 路径注册表无法写入 无法保存 SteamVR 所需的路径。您的权限设置可能不正确 – 确保您可以写入电脑上的用户目录。 (200) 驱动程序失败 OpenVR 驱动程序失败。您的权限设置可能不正确 – 确保您可以写入电脑上的用户目录。如果您曾经手动添加内容至 SteamVR 驱动程序目录…

htcvr设备计算机配置,htc vive 电脑配置:深挖和HTC Vive绝配的笔记本 几万块一台...

在PC市道日渐低迷的今天&#xff0c;或许会因为像HTC Vive这类VR设备的面世&#xff0c;而使PC迎来了第二春。VR对PC的高要求&#xff0c;让高配置主机多了一个新的面向群体&#xff0c;随着VR的普及&#xff0c;高配置PC会逐渐变得亲民。 这里不仅体现在电脑主机方面&#xff…

多普达与HTC关系

每当提起PPC或smartphone智能手机&#xff0c;人们总是首先想起多普达。对&#xff0c;多普达无论是在PPC领域还是smartphone领域给人的影响都是非常深刻的&#xff0c;因为多普达一直专注做智能手机。 关注水货手机的朋友可能已经留意到了&#xff0c;多普达同一款产品总会有…