美文网首页
JS进阶系列01-JS的弱类型和动态类型

JS进阶系列01-JS的弱类型和动态类型

作者: love丁酥酥 | 来源:发表于2018-03-25 00:25 被阅读87次

1. 弱类型,强类型,动态类型,静态类型的区别

首先,我们要弄清楚编程语言的两组划分,即弱类型和强类型,动态类型和静态类型。下面有一幅图,非常详细地说明了它们各自的定义和区别。

动态/静态,强类型/弱类型-转
该图转自编程语言傻傻分不清:弱类型、强类型、动态类型、静态类型一文,大家可以前往该文章查看编程语言这两组划分的详细定义和区别。

2. JS的弱类型和动态类型

JS种有5种基本数据类型:Undefined,Null,Boolean,Number和String,以及一种复杂数据类型Object。但JS的变量在声明时无需指定其类型,而是统一使用var关键字。并且在其声明之后,我们可以为其随便赋值不同的类型。
JS由于不需要关注变量的类型,可以使代码更加简洁,也能使开发者集中更多的精力在处理业务逻辑之上。但由于其无法保证变量类型,从而在程序运行期可能发生跟类型相关的错误。 比如:

var s = 1;
s();  //Uncaught TypeError: s is not a function

而这样的错误对于JAVA在编译期间就会检查出来。

3. JS鸭子类型的思想

(这一节的内容大家可以直接看BOOK-《JavaScript设计模式与开发实践》 第一部分)

JS对变量类型的宽容给实际编码带来了很大的灵活性,由于无需进行类型检测,开发者可以尝试调用任意对象的任意方法,而无须去考虑它原本是否被设计为拥有该方法。

这一切都建立在鸭子类型(duck typing)的概念上。鸭子类型的通俗说法是:“如果它走起路来像鸭子,叫起来也是鸭子,那么它就是鸭子。”

有个很形象的例子:

从前在Javascript王国里,有一个国王,他觉得世界上最美妙的声音就是鸭子的叫声,于是国王召集大臣,要组建一个1000只鸭子组成的合唱团。大臣们找遍了全国终于找到999只鸭子,但是始终还差一只,最后大臣发现一直特别的鸡,它的叫声跟鸭子一模一样,于是这只鸡就成为了合唱团的最后一员。

这个故事告诉我们,国王要听的只是鸭子的叫声,这个声音的主人到底是一个鸡还是要鸭子并不重要。鸭子类型指导我们只关注对象的行为,而不关注对象本身,也就是关注HAS-A(拥有什么),而不是IS-A(是什么)。

下面我们用代码模拟这个故事:

var duck={
    duckSinging:function(){
        console.log("噶嘎嘎");
    }
};
var chicken={
    duckSinging: function () {
        console.log("噶嘎嘎");
    }
};
var choir=[]; //合唱团
var joinChoir=function(animal){
    if(animal&&typeof animal.duckSinging==='function'){
        choir.push(animal);
        console.log("恭喜加入合唱团");
        console.log("合唱团已有成员:"+choir.length);
    }
};
joinChoir(duck);
joinChoir(chicken);

我们看到,对于加入合唱团的动物,大臣们根本无需检查它们的类型,而是只需要保证它们拥有duckSinging方法。如果下次期望加入合唱团的是一只小狗,而这只小狗刚好也会鸭子叫,我相信这只小狗也能顺利加入。

在动态类型语言的面向对象设计中。鸭子类型的概念至关重要。利用鸭子类型的思想,我们不必借助超类型的帮助,就能轻松地在动态类型语言中实现一个原则:“面向接口编程,而不是面向实现编程”。例如,一个对象若有push和pop方法,并且这些方法提供了正确的实现,它就可以被用来当作栈使用。一个对象如果有了length属性,也可以依照下标来存取属性(最好还要拥有slice和splice等方法),这个对象就可以被当做数组来使用。

参考

编程语言傻傻分不清:弱类型、强类型、动态类型、静态类型
BOOK-《JavaScript设计模式与开发实践》 第一部分

相关文章

  • JS进阶系列01-JS的弱类型和动态类型

    1. 弱类型,强类型,动态类型,静态类型的区别 首先,我们要弄清楚编程语言的两组划分,即弱类型和强类型,动态类型和...

  • Flow基本语法及使用

    js编程存在的问题 js弱类型的动态类型检查语言弱类型: 被声明时可以赋值为任何数据动态类型: 类型检查会在运行时...

  • JavaScript-变量、值与类型

    1.关于JS类型的几点说明: JS是动态类型+弱类型的语言; JS的变量、属性在运行期决定类型; JS存在隐式类型...

  • 2018-06-28 js 变量提升

    js 变量提升 首先 javascript 是一种弱类型、动态的、解释型的脚本语言。 弱类型:类型检查不严格,偏...

  • JS重要知识点-10月份

    1 javascript 是一种动态类型、弱类型、基于原型的语言 2 JS有五种基本数据类型和一个引用类型,Obj...

  • js(1)-正则表达式

    JS的简介概述: JavaScript, 是一门弱类型的语言, 可以给页面增加动态效果.//弱类型的语言: 对数据...

  • Typescript

    js:弱类型语言,动态类型,容易出错,维护成本较高ts: 微软创建的,以js为基础构建的语言。 js的超集,引入类...

  • JS笔记

    一.JS简介 1.什么是JS JS全称为JavaScript, 是一门运行在浏览器的, 动态类型的, 弱类型的(数...

  • JS基础加随堂练习

    JS 1、js简介 JavaScript是一种基于对象的客户端的脚本语言 是一种弱类型的动态脚本语言 弱类型:对数...

  • JS基础教程

    JS 1、js简介 JavaScript是一种基于对象的客户端的脚本语言 是一种弱类型的动态脚本语言 弱类型:对数...

网友评论

      本文标题:JS进阶系列01-JS的弱类型和动态类型

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