Maison >interface Web >js tutoriel >Révision des bases de Javascript (1)

Révision des bases de Javascript (1)

高洛峰
高洛峰original
2017-02-04 14:49:241150parcourir

À l'origine, j'allais continuer le dernier article de la série d'expressions du simple au profond, mais récemment, l'équipe est soudainement devenue occupée, plus occupée que jamais ! Mais amis qui aiment les expressions, ne vous inquiétez pas, je suis déjà en train de l'écrire :) Au travail, j'ai trouvé que tout le monde comprenait un peu quelques principes de base de Javascript ici ou là, alors j'ai décidé de passer un peu de temps à trier ces connaissances de base et les partager avec vous. Au début, j'avais prévu d'écrire un article, mais au fur et à mesure que je continuais à écrire, j'en ai trouvé de plus en plus, j'ai donc décidé d'écrire une série. Tout le contenu de cette série implique les bases de Javascript, et il n'y a rien de compliqué, mais je pense que ces éléments de base vous aideront à comprendre les choses intéressantes.

Oui, quand il s'agit de Javascript, tout ce à quoi je pense, c'est amusant et amusant ! Alors, quels endroits sont amusants et pourquoi le sont-ils ? Jouons ensemble, comprenons parfaitement Javascript tout en jouant. Contenu inclus dans cet article :

Types de base
Objet et objet
Types d'emballage de base
Types de valeur et types de référence
Types de fonctions

Types de base
Javascript dispose de 5 types de données de base (également appelés types de données simples) : Non défini, Null, Booléen, Nombre, Chaîne et 1 type de données complexe Objet.

var undefinedVariable;
var nullValue = null;
var cnblogs = new Object();
var func = function () { };
 
typeof ("string"); 
typeof (100);
typeof (true);
typeof (undefinedVariable);
typeof (cnblogs);
typeof (undeclaredValue);
typeof (nullValue);
typeof (null)
typeof (func)

Dites-moi quel est le résultat ?

Javascript基础回顾之(一) 类型

Javascript基础回顾之(一) 类型

Un amusant : les variables déclarées mais non attribuées et non déclarées sont toutes indéfinies
Deuxième partie amusante : uniquement déclarées et si la valeur est null, sa valeur sera null
Fun 3 : typeof(Object) s'avère être une fonction
Fun 4 : typeof(null) s'avère être un objet

Null et Undefined Les deux types n'ont qu'une seule valeur, nulle et indéfinie. Logiquement, la valeur nulle représente un pointeur vers un objet nul, c'est pourquoi typeof(null) renvoie Object. Et undefined est dérivé de la valeur nulle, donc...

Amusant n°5 : null == undefined est vrai.

Mais réfléchissez-y, Null et Undefined sont deux types différents après tout. Même s'il s'agit de la relation entre la classe parent et la classe enfant, la classe parent et la classe enfant ne peuvent pas être égales en C#, n'est-ce pas ? En fait, null == undefined est une règle stricte qui stipule qu'ils doivent renvoyer true lors des tests d'égalité, ils renvoient donc true. C'est comme si nous avions remplacé la méthode equlas en C#.

Quant à savoir pourquoi typeof(Object) renvoie la fonction, veuillez consulter Objet et objet ci-dessous.

Objet et objet
Il est dit dans le livre Javascript Advanced Programming que "les fonctions sont des objets dans ECMAScript, pas un type de données". Il semble que le traducteur l'ait ajouté puisque typeof(Object) renvoie une fonction, pourquoi dit-on que la fonction n'est pas un type de données ? Quelle est la relation entre objet et fonction ?

À mon avis, Object est en fait une fonction, ou nous disons que Object est une fonction dont le nom est plus facile à comprendre. Le nom officiel est constructeur.

var p = new Object();
p.name = "jesse";
p.age = 18;
 
function Person(name,age)
{
 this.name = name;
 this.age = age;
}
 
var p2 = new Person("jesse", 18);

Dans le code ci-dessus, si nous traitons Object comme un nom de fonction, alors les propriétés de new Object() et new Person() sont les mêmes. Une instance de fonction est obtenue via l'opérateur new et la fonction qu'elle contient est déjà un concept de classe. L'objet ici est donc en fait une fonction. De cette façon, nous pouvons expliquer pourquoi typeof(Object) est une fonction.

Alors, quel est l'objet de type complexe que nous avons mentionné ci-dessus ?

Javascript基础回顾之(一) 类型

Object est une fonction, mais new Object() est un objet. À ce stade, il est clair que l'objet avec la première lettre en majuscules est une fonction et que l'objet avec la première lettre en minuscules est un type de données. Je suggère donc à tout le monde d'utiliser des lettres minuscules lorsqu'il parlera de types à l'avenir. Nos types de base sont les chaînes, les nombres et les booléens. La chaîne majuscule, le nombre et la valeur booléenne ne sont qu'une fonction. Le résultat de l’appel de ces fonctions est, oui, un objet.

Javascript基础回顾之(一) 类型

Enfin, nous ne trouvons pas les deux fonctions Undefined et Null, donc les deux types de données sont indéfinis et null (pourquoi typeof(null) obtiendra l'objet Déjà dit)

Javascript基础回顾之(一) 类型

Fun n°6 : L'objet n'est pas un type d'objet

基本包装类型
  我们上面讲了string, number, boolean是基本类型,基本类型和复杂类型最大的区别就是基本类型没有prototype属性。也就意味着你不能给基本类型随意的添加方法或属性。

var str = "str"; // typeof(str): string
var strObj = new String("str"); // typeof(strObj):object
 
strObj.name = "strObj";
strObj.alert = function () {
 alert(this.name);
};
strObj.alert(); // strObj
 
str.name = "str"; //wrong...
str.alert = function () {
 alert(this);
}
str.alert(); // this is wrong.... nothing is gonna happen.

同时我们还说到了首字母大写的这个String是一个function,所以new String("str")得到的是一个object而不是一个string,这里大家要搞清楚了。我们的问题来了,为什么基本类型string会有一些初始的方法呢?它不是基本类型么?方法是怎么加上去的?

str = str.concat("str2");
strObj = strObj.concat("str2");
strObj.alert(); //之后返回 string 不再是一个对象了, 所以这里也不再有alert方法了。

str是string类型的变量,记住它不是一个对象。它是不应该有方法的,那么它的contact方法从何而来呢?这里后台在调用str.contact的时候实际上偷偷的完成了几步操作:

基于str创建一个String类型的实例

在实例上调用指定的方法

销毁这个实例

  将这三个步骤想象成这样:

var str2 = new String(str);
str = str2.concat("str2");
str2= null;

我们可以把String,Number,Boolean叫做封装类型, 他们就好像我们在C#里面的自定义类型一样。 但是不要忘记了我们真正的基本类型是string, number, boolean。用String所构造出来的对象是属于object类型的。

好玩之七: String 不是 string
值类型和引用类型
  我们上面讲到了5种基本类型:string, number, boolean, null, undefined 全部是值类型。Javascript中只有一种引用类型,也就是我们的复杂类型object。那么有人可能会好奇,那么像Date, Regex, Arrary这些是什么类型呢 ? 其实这里面的概念有一点混淆,如果你很好的理解了上面的Object 和object之间的区别,可能会比较好理解一点。 我们可以把function 看成是C#里面 class关键字,我们可以用class定义类,同样我们可以在Javascript中用function来定义类。

在C#中定义类:

namespace ConsoleApplication1
{
class Person
{
 public string Name { get; set; }
  
 public int Age { get; set; }
}
  
class Program
{
 static void Main(string[] args)
 {
 var p =new Person();
 Console.WriteLine(p.GetType()); // ConsoleApplication1.Person
  
 Console.ReadLine();
 }
}
}

在Javascript定义类:

function Person(name,age)
{
 this.name = name;
 this.age = age;
}
 
var p = new Person();
typeof(p); //object

你发现区别了么?如果我们在Javascript中用function定义类,他们的实例将永远是object, 包括原生的那些Date, Array, RegExp。

typeof (new Date()); // object
typeof (new Array()); // object
typeof (new RegExp()); // object

Javascript基础回顾之(一) 类型

好玩之八: 全部都是object
  如果全部都是object的话,那我怎么能知道这个对象到底是不是Date或者Person的实例呢?借助于instanceof 就可以了。

Javascript基础回顾之(一) 类型

终级好玩:我用function创建了一个Person类,然后用new得到一个Person的实例,结果它却不是Person类型的。 这就好像生了个孩子,供他吃穿,但是他却不跟你姓,这得有多么无私伟大才干得出来的事啊!
function类型
  function类型有两种,函数声明和函数表达式。函数声明具有优先级,可以在声明之前被使用,表达式却不能。

sayGoodNight(); // right
sayHello(); // wrong
 
var sayHello = function (name) {
 alert("Hello, " + name);
};
 
function sayGoodNight(Name) {
 alert("Good Night, "+ name);
}

除此之外,函数表达式还可以像object一样,随意的添加属性。

var sayHello = function (name) {
 alert("Hello, " + name);
};
 
sayHello.age = 18;
sayHello.sayAge = function () {
 alert("I am" + 18) ;
}
sayHello.sayAge(); // I am 18

但是,函数表达式到底是个什么玩意儿呢? 不能实例化,但是可以随意的添加属性,它和object有什么区别?我们在上面说过,object其实就是一个对象实例。

我们还有大写的Function, 它和function之间的关系会不会和String 和string 一样?( 以下内容比较费脑力,慎入!)

var sayHello = new Function('name','alert("My name is " + name );');
sayHello('Jesse');
sayHello instanceof Function; // true
 
var sayHello2 = function (name) {
 alert('My name is' + name);
};
sayHello2 instanceof Function; // true

我们上面调用Function去构造了一个函数。既没有用函数声明,也没有用函数表达式,不管怎么说这是第三种创建函数的方法,虽然肯定没有多少人用它,因为它不管是参数,还是函数体全部都是字符串,这写起来还不让人崩溃么?

Javascript基础回顾之(一) 类型

Javascript基础回顾之(一) 类型

看出什么猫腻来了么?所谓的函数表达式,其实是用一个变量接收了一个function的对象而已。而这个function的对象则是Function的实例。包括用函数声明写出来的函数也是Function的实例。

function sayHello3(name)
{
 alert('My name is' + name);
}
sayHello3 instanceof Function; // true

但是,等等,我们前面说到的String, Date, Array都是function类型的,那Function也是么?

Javascript基础回顾之(一) 类型

我们前面说所有function的实例都是object类型的,但是对于Function 这个奇异的function来说,它的实例仍然是function类型的,并且我们可以用Function的实例再创造实例。原来我们所说的用function创造出来的类,它不是类,而是Function的实例。

function Person(name) {
 this.name = name;
}
Person instanceof Function; // true

我们再结合自执行函数理解一下,也许会好一点:

(function () {
 alert("something...");
}());

实际上我们上面的function(){} 会返回给我们一个function的实例,那么我们当然可以直接执行它了。这么看来function应该是Javascript里面最特别的类型了。

好玩之十:所有的function都是Function的实例
好玩之十一:Function 本身也是一个function

Javascript基础回顾之(一) 类型

最后我们来总结一下:

Javascript中有5种基本类型:string, number, boolean, null, undefined。

另外一种复杂类型object 其实是function的实例。

除了Function这个系统里面的function构造器以外,其它所有function的实例都是object类型的。

Date, Array, RegExp 这些都是function类型,同时也是Function的实例。同理,它们的实例也是object类型的。

总结完了,好像也不多,不是么?关于function其实javascript是非常强大的一个功能,作用域以及面向对象的一些知识也是和它息息相关的,我们下一篇就来看看作用域的问题。谢谢大家的关注!

更多Javascript基础回顾之(一) 类型相关文章请关注PHP中文网!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn