当前位置: 移动技术网 > IT编程>网页制作>技巧 > HTC基础知识

HTC基础知识

2017年12月01日  | 移动技术网IT编程  | 我要评论

邢氏之子,联想天逸f41at5800,说岳全传连环画

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>


如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网