zoukankan      html  css  js  c++  java
  • nodejs 语法很特别的地方

    1. 不过我们之前说过了有 this 和没 this 的时候作用域不同,那个参数只是作用于构造函数中,而加了 this 的那个则是成员变量。用一个 this 就马上区分开来他们了,所以即使同名也没关系。

    2. 类的声明和实例化

    声明一个类非常简单,大家不要笑:

    javascript
    function foo() {
        //...
    }
    好了,我们已经写好了一个 foo 类了。

    真的假的?!真的。

    不信?不信你可以接下去打一段代码看看:

    javascript
    var bar = new foo();
    别看它是一个函数,如果以这样的形式(new)写出来,它就是这个类的实例化。

    而这个所谓的 foo() 其实就是这个 foo() 类的构造函数。

    3.  写成员变量的方法:

    第一种方法:

    复制代码代码如下:

    javascript
    function foo() {
        this.hello = "world";
    }

    注意:只有在加了 this 的时候才是调用类的成员变量,否则只是函数内的一个局部变量而已。要分清楚有没有 this 的时候变量的作用范围。

    第二种方法就是在构造函数或者任何成员函数外部声明,其格式是 <类名>.prototype.<变量名>:

    4.  传递参数可多于或者少于声明。

    我们一开始就说了 JavaScript 是一门弱类型语言,其实不仅仅是弱类型,它的传参数也非常不严谨。你可以多传或者少传(只要保证你多传或者少传的时候可以保证程序不出错,或者逻辑不出错),原则上都是可以的。多传的参数会被自动忽略,而少传的参数会以 undefined 补足。

    5. 类的随意性

    这个又是我胡扯的。所谓类的随意性即 JavaScript 中你可以在任何地方修改你的类,这跟 Ruby 有着一定的相似之处。

    比如说 string ,它其实也是一个类,有着诸如 length 这样的成员变量,也有 indexOf、substr 等成员函数。但是万一我们觉得这个 string 有些地方不完善,想加自己的方法,那么可以在你想要的地方给它增加一个函数,比如:

    javascript

    复制代码代码如下:

    String.prototype.sb = function() {
      var newstr = "";
      for(var i = 0; i < this.length; i++) {
        if(i % 2 === 0) newstr += "s";
        else newstr += "b";
      }
      return newstr;
    };

    6. 深拷贝

    所谓深拷贝就是自己新建一个数组或者对象,把源数组或者对象中的基础类型变量值一个个手动拷过去,而不是只把源数组或者对象的引用拿过来。所以这就涉及到了一个递归的调用什么的。

    下面是我实现的一个深拷贝函数,大家可以写一个自己的然后加入到自己的 Node.js 知识库中。

    javascript

    复制代码代码如下:

    function cloneObject(src) {
      var dest = {};
      for(var key in src) {
        if(typeof src === "object") dest[key] = cloneObject(src[key]);
        else dest[key] = src[key];
      }
      return dest;
    }
  • 相关阅读:
    iOS BUG整理-记录我近期视频开发遇到的问题
    iOS 翻译-UIWebView的基本简介-官方文档翻译
    iOS 翻译-Xcode使用-文档翻译
    4.redis设计与实现--跳跃表
    3.redis设计与实现--字典
    2.redis设计与实现--链表
    1.redis设计与实现--简单动态字符串
    12.编码问题讨论
    11.nginx upload module + python django 后台 实现视频上传与切片
    10.nginx+ffmpeg上搭建HLS切片
  • 原文地址:https://www.cnblogs.com/wxmdevelop/p/4435980.html
Copyright © 2011-2022 走看看