class类可以完成的事情,我们使用普通的function以及变量定义也能完成,所以很多情况下,我们都是使用后者来完成业务,class用的地方不多,但class有它自己的属性、方法,可以加默认值,它也可以继承,在项目中,有哪些地方是我们可以合理利用class方法的?class主要是用来干什么的?
比如 class 中对属性的描述关键字还是挺全面,比如:public、private、static 等一些关键字,使它能够更直观的对自己的属性进行更好的保护与使用,这个是 function 所不能比的,还有就是 this 的问题。所以使用场景不同,选择就不同,但是 function 更灵活,对于前端来说,也更方便操作。所以没必要纠结这些。
首先要明白,js 是 多范式编程语言 ,这就意味着,面向对象并不是必须的语法,所以题主才会有这种疑问,这也是实际情况
在 js 中,函数是 一等公民 :
立即执行函数、高阶函数、闭包、链式调用、函数柯里化,这些特性也全和函数有关,所以可以说函数式编程是 js 的 灵魂 所在
一般来说面向对象能实现的(至少在 js 中)函数式编程也能实现
在 ES6 之前,js 的函数依赖 原型链 来模拟面向对象的过程
// 定义一个构造函数 Personfunction Person(name, age) { this.name = name; this.age = age;}// 在 Person 的原型上定义方法Person.prototype.sayHello = function() { console.log("我叫 " + this.name + ",已经 " + this.age + " 岁了");};// 创建 Person 的实例var person1 = new Person("Lagrange", 25);// 调用实例的方法person1.sayHello();
你看,是不是和面向对象几乎一致?
正如回答开头所说: js 是 多 范式编程语言,自然会考虑开发者更全面的需求,为开发提供更多选择,也是为了可读性(如果对原型链了解不多,可能会疑惑为什么有的方法在原型上,有的方法又直接加在函数里)
直接通过关键字声明,统一一套规范,总比各自作各自的实现要好(在此之前, js 不止一套方法实现面向对象,因为函数式编程确实很灵活)
可谓百家争鸣,列举主要的几种
为了一个面向对象,不得不学习一堆实现模式,属实有些折磨(虽然学习不同的实现方案挺有意思的)
因此,ES6 出手了,借一句话,就是 车同轨,书同文
大家别再自己创造了,按我的规范来,类就用 class
定义,构造函数就叫 constructor
,实例方法直接写,静态方法加 static
,也不用手动在原型链上写来写去了,语法糖统统帮你实现
class Person { constructor(name, age) { this.name = name; this.age = age; } // 实例方法 sayHello() { console.log(`我叫 ${this.name}`); } // 静态方法 static info() { console.log('静态方法'); }}// 最终调用倒是差不多const person2 = new Person("Lagrange", 25);person2.sayHello();
OP 的问题开头其实已经接近jsclass
的本质了, JavaScript 语言中,生成实例对象的传统方法是通过构造函数。下面是一个例子。
function Point(x, y) { this.x = x; this.y = y;}Point.prototype.toString = function () { return '(' + this.x + ', ' + this.y + ')';};var p = new Point(1, 2);
上面这种写法跟传统的面向对象语言(比如 C++ 和 Java)差异很大,很容易让新学习这门语言的程序员感到困惑。
ES6 提供了更接近传统语言的写法,引入了 Class
(类)这个概念,作为对象的模板。通过class关键字,可以定义类。
基本上,ES6 的class
可以看作只是一个语法糖,
上面的代码用 ES6 的class改写,就是下面这样。
class Point { constructor(x, y) { this.x = x; this.y = y; } toString() { return '(' + this.x + ', ' + this.y + ')'; }}
上面代码表明,类的数据类型就是函数,类本身就指向构造函数。
使用的时候,也是直接对类使用new命令,跟构造函数的用法完全一致。
class Bar { doStuff() { console.log('stuff'); }}var b = new Bar();b.doStuff() // "stuff"
构造函数的prototype属性,在 ES6 的“类”上面继续存在。事实上,类的所有方法都定义在类的prototype属性上面。
class Point { constructor() { // ... } toString() { // ... } toValue() { // ... }}// 等同于Point.prototype = { constructor() {}, toString() {}, toValue() {},};
在类的实例上面调用方法,其实就是调用原型上的方法。
class B {}let b = new B();b.constructor === B.prototype.constructor // true
上面代码中,b是B类的实例,它的constructor方法就是B类原型的constructor方法。
因此你看, 其实本质没有什么区别, 只是更像面向对象而已
使用的场景也就与OOP对应
https://www.bookstack.cn/read/es6-3rd/spilt.1.docs-class.md
问题内容: 什么是真正做? 它的定义是 刷新实体时,此字段中保存的所有实体也会刷新 但这实际上意味着什么?有人可以给我一个简单的例子吗? 问题答案: 单独的CascadeType描述可能会有些混乱,但是有一种简单的方法可以从一般情况中找出来。 对于任何值,这意味着如果使用接口在实例上调用了操作,并且该实例具有对其他实体实例的引用,并且已经定义了关联,则该操作也将应用于该关联实体。 因此定义为: 从
前端的知识点是零碎的,中高阶前端开发人员能做哪些技术项目,提高自己的抽象和架构层次呢?
我只是第一次涉足iOS开发,我必须做的第一件事就是实现一个自定义容器视图控制器——让我们称之为SideBarViewController——它交换了几种可能的视图控制器中的哪一种它显示的子视图控制器,几乎与标准的Tab Bar Controller一模一样。(它几乎是一个标签栏控制器,但有一个可隐藏的侧菜单,而不是标签栏。) 根据Apple文档中的说明,每当我向容器中添加子ViewControll
报错提示: “Type”表示值,但在此处用作类型。是否指“类型 Type”? 我传入的Type 是一个class类 ,然后里面想要这样指定类型 这个可以做到么 有什么好的方式?
通过print-js打印出来的小票是乱码的,貌似是字符编码的问题,网上找过很多方案,基本上都是说字符编码格式的问题,或者直接用electron来实现的,请问大家对于前端热敏纸小票打印都是用的什么解决方案?
我在看最新的开发者IDE: Zed的时候, 发现它有一个标签:gpui 请问gpui是什么? 和 GPU 有关系吗?