zoukankan      html  css  js  c++  java
  • javascript高级程序设计学习小结3

    DOM2级只是在DOM1级的基础上通过增加新方法和新属性来增强既有类型,Node类型的变化: localName(不带命名空间前缀的节点名称), namespaceURI(命名空间URI或者null), prefix(命名空间前缀)

    “DOM2级视图”模块添加了一个名为defaultView的属性,其中保存着一个指针,指向拥有给定文档的窗口。

    DOM2级遍历和范围模块定义了两个用于辅助完成顺序遍历DOM结构的类型: NodeIterator 和TreeWalker。以及DOM中的范围 var range = document.createRange(), 而要通过范围来选择文档中的一部分,可以使用selectNode()或者selectNodeContent()

    DOM3级同样增强了既有类型,但也引入了一些新类型

    isDefaultNamespace(namespaceURI): 在指定的namespaceURI是当前节点的默认命名空间的情况下返回true

    lookupNamespaceURI(prefix): 返回prefix的命名空间

    lookupPrefix(namespaceURI):返回给定namespaceURI的前缀

    另外引入了两个辅助比较节点的方法: isSameNode() 和 isEqualNode()

    DOM3还针对为DOM节点添加额外数据引入的新方法 setUserData(key, value, function), 获取数据getUserData(key);

    确定元素大小

    function getBoundingClientRect(element) {
        if (typeof arguments.callee.offset != "number") {
            var scrollTop = document.documentElement.scrollTop;
            var temp = document.screateElement("div");
            temp.style.cssText = "position:absolute;left:0;top:0;";
            document.body.appendChild(temp);
            arguments.callee.offset = -temp.getBoundingClientRect().top - scrollTop;
            document.body.removeChild(temp);
            temp = null;  
        }
        var rect = element.getBoundingClientRect();
        var offset = arguments.callee.offset;
        return {
            left: rect.left + offset,
            right: rect.right + offset,
            top: rect.top + offset,
            bottom: rect.bottom + offset
        };
    }    

     在处理文本框的值时,最好不要使用DOM方法,因为对value属性所做的修改不一定能反映在DOM中。

    文本框中选择部分文本

    function selectText(textbox, startIndex, stopIndex) {
        if (textbox.setSelectionRange) {
           textbox.setSelectionRange(startIndex, stopIndex);
        } else if (textbox.createTextRange) {
            var range = textbox.createTextRange();
            range.collapse(true);
            range.moveStart("character", startIndex);
            range.moveEnd("character", stopIndex - startIndex);
            range.select();
        }
        text.focus();
    }

    FormData为序列化表单以及创建与表单格式相同的数据(用于通过XHR传输)提供了便利。体现在: 不必明确在XHR对象上设置请求头部,XHR对象能够识别传入的数据类型是FormData的实例,并配置适当的头部信息。 CORS的基本思想是使用自定义的HTTP头部让浏览器与服务器进行沟通,从而决定请求或者响应是否是应该成功还是失败。

    跨域技术:(1)图像Ping, (2) JSONP

    为确保通过XHR访问的URL安全,通行的做法就是验证发送请求者是否有权限访问相应的资源,有两种方式可供选择,1)要求以SSL连接来访问可以通过XHR请求的资源;2)要求每一次请求都要附带经过相应算法计算得到的验证码

  • 相关阅读:
    django缓存,信号,orm性能,多数据库配置
    git实战
    Web框架
    Windows Server 2012 R2 管理员密码忘记如何修改密码
    主机记录和记录值
    Python的类
    GenomicRangeQuery Find the minimal nucleotide from a range of sequence DNA.
    Countdiv-Codility Lesson5
    Windows域控时间不正确,设置互联网NTP服务器时间自动同步
    Missing Smallest positive integer
  • 原文地址:https://www.cnblogs.com/fesf/p/7727205.html
Copyright © 2011-2022 走看看