• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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教程
    下一篇:Web上功能强大的DbGrid表格HTC组件[只需在Table中指定样式就可以完成多种功能可扩展]
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    HTC基础知识 HTC,基础知识,HTC,基础知识,