美文网首页javaScript学习程序员
《JavaScript DOM 编程艺术》09:最佳实践

《JavaScript DOM 编程艺术》09:最佳实践

作者: ZackLive | 来源:发表于2018-09-10 13:29 被阅读0次

    本文同步发表于我的个人网站:ZackLive

    这是《JavaScript学徒》系列的第九课,今天会进入《JavaScript DOM 编程艺术》第5章,谈谈JavaScript的最佳实践。

    教学视频连结

    YouTube

    优酷

    B站

    平穏退化

    平穏退化是指即使访问者的浏览器不支持JavaScript,网页也可能完成基本操作。

    例如:

    window.open(url, name, features);

    这是一个BOM方法(用到window,和浏览器相关),不影响DOM(用document,和HTML文档相关)。用来创建新浏览器窗口。

    三个参数分别代表:

    新窗口要打开的网页URL,若少了这个参数,会创建空白窗口。

    新窗口的名字,可通过该名字操作新窗口。

    一个以逗号分隔的字符串,为新窗口的各种属性,如宽度与高度。

    一种典型的应用是将它放在一个函数里:

    function popUp(winURL) {

      window.open(winURL, "popup", "width=320,height=480");

    }

    和之前一样,将这个函数放在一个外部文件(如myScript.js)中,再通过标签导入到HTML当中。

    调用这个函数的常见方法有两种,一是”javascript:“伪协议,二是内嵌的事件处理函数。

    所谓真协议是指电脑之间传输数据包的协议,如HTTP、FTP等;而伪协议是非标准化的协议。“javascript:“伪协议可以通过一个连结来调来JavaScript函数:

    < a href="javascript:popUp('https://zacklive.com');">Example< /a>

    内嵌事件处理函数的做法就是透过onclick事件调用函数:

    < a href="#" onclick="popUp('https://zacklive.com'); return false;">Example< /a>

    #代表文档开头。

    这两个方法的问题是,当JavaScript被禁示时,连结也会无效。更好的做法是,将网址放在href当中,再透过this.href调用:

    < a href="https://zacklive.com" onclick="popUp(this.href; return false;)">Example< /a>

    但这样还不够好,因此JavaScript代码出现在HTML当中,最好能将JavaScript分离到外部文件中。

    分离JavaScript

    最理想的情况是,所有JavaScript代码都放在一个独立的文件中,HTML文档中透过载入这个文件。

    在JavaScript中,可以将事件添加到元素当中:

    element.event = action

    我们可以通过给元素添加特定的id或class来找到这些元素,例如:

    < a href="https://zacklive.com" class="popup">Example< /a>

    透过遍历文档中所有连结,只要有popup这个class就给这个连结的onclick事加入popUp函数:

    window.onload = prepareLinks;

    function prepareLinks() {

      var links = document.getElementsByTagName("a");

      for (var i = 0; i < links.length; i++) {

        if (links[i].getAttribute("class") == "popup") {

          links[i].onclick =  function() {

            popUp(this.getAttribute("href"));

            return false;

          }

        }

      }

    }

    window.onload是确保整个HTML文档加载完成后,再执行JavaScript,避免发生JavaScript文件先载入完成,但HTML文档(也就是DOM)还没准备好。

    向后兼容

    另一个要考虑的问题是,浏览器对JavaScript的支持程度不一样。某些访问者的浏览器由于版本较旧等原因,不支持某些方法。可以透过以下方式检查:

    if (!getElementById) return false;

    即,若不支持getElementById,马上结束函数并返回false。

    上面的函数就变成:

    window.onload = prepareLinks;

    function prepareLinks() {

      if (!document.getElementsByTagName) return false;

      var links = document.getElementsByTagName("a");

      for (var i = 0; i < links.length; i++) {

        if (links[i].getAttribute("class") == "popup") {

          links[i].onclick =  function() {

            popUp(this.getAttribute("href"));

            return false;

          }

        }

      }

    }

    性能考虑

    少访问DOM和减少标记

    每执行一次document.getElementById等DOM方法,就会搜索整个DOM一次。需要多次用到搜索结果时,可以将第一次的结果存到一个变量当中,之后就使用这个变量,便无需再度搜索DOM。如:

    var links = document.getElementsByTagName("a");

    另外,HTML文档中标签越多,DOM的规模就越大,搜索的成本也就越高,因此,可尽量减少标签数量。

    合并脚本

    尽量将JavaScript代码全部放在一个文件中,而不要分开在多个脚本文件,因为每个标签都会向服务器发出一次请求,请求越多,网页的载入速度越慢。

    之前也讲过,最好将标签放在文档最后,即之前,这样网页载入得更快。

    压缩脚本

    最后一步是压缩脚本,即去除脚本中不必要的东西,如空格和注释等。压缩后的代码不好读,但可以减少文件大小,可将它另存一个文件,在文件名加入min字样:myScript.min.js。

    压缩的工作可交给Uglify JS完成:http://lisperator.net/uglifyjs/

    相关文章

      网友评论

        本文标题:《JavaScript DOM 编程艺术》09:最佳实践

        本文链接:https://www.haomeiwen.com/subject/tclsgftx.html