前端培训-初级阶段(13)-类,模块,继承

简介: 前端最基础的就是 HTML+CSS+Javascript。掌握了这三门技术就算入门,但也仅仅是入门,现在前端开发的定义已经远远不止这些。前端小课堂(HTML/CSS/JS),本着提升技术水平,打牢基础知识的中心思想,我们开课啦(每周四)。该文为前端培训-初级阶段(13、18)的补充内容 (介绍了 ECMAScript 历史,ES6 常用点)。本文介绍ECMAScript基础知识。前端培训-初级阶段(13) - ECMAScript (语法、变量、值、类型、运算符、语句)前端培训-初级阶段(13) - ECMAScript (内置对象、函数)基础内容知识我们会用到。默认已读。

我们要讲什么


  • js 中的类


  • js 中的模块


  • js 中的继承实现



在 JavaScript 中,类的实现是基于原型继承机制的。如果两个实例都从同一个原型对象上继承了属性,我们说它们是同一个类的实例。

ES6 提供了更接近传统语言的写法,引入了 Class(类)这个概念。通过class关键字,可以定义类。

ES6 的 Class 可以看作是一个语法糖,它的绝大部分功能,ES5 都可以做到,新的class写法只是让对象原型的写法更加清晰、更像面向对象编程的语法而已。

class Logger {
  constructor(wigName) {
    this.wigName = wigName;
  }
  warn(info) {
    return console.log(`${this.wigName}-${info}`)
  }
}
logger = new Logger('lilnong.top')
logger.warn('404')
//ES5 中怎么写
function Logger(wigName){this.wigName = wigName;}
Logger.prototype.warn = function(info){
    return console.log(`${this.wigName}-${info}`)
}
logger = new Logger('lilnong.top-ES5')
logger.warn('404')

如图 ES6 其实也还是在prototype


bVbsmwj.webp.jpg


ES6 的 Class还有一些特殊的功能,比如必须通过 new 来实例化。那么我们的 ES5 怎么来实现这个功能?(话说 ES6 怎么在低版本实现可以去在线 babel)


  1. function fun(){console.log(new.target)};console.log(fun(),new fun())通过新加的 new.target来区分。


  1. function fun(){console.log(this instanceof fun)};console.log(fun(),new fun())这个方法就是通过 new 的特性是判断,面试题new的时候系统做了几步操作


  1. 创建一个空对象
  2. 空对象绑在 this 上
  3. 然后调用


模块


历史上,JavaScript 一直没有模块(module)体系,无法将一个大程序拆分成互相依赖的小文件,再用简单的方法拼装起来。

其他语言都有这项功能,比如 Ruby 的require、Python 的import,甚至就连 CSS 都有@import,但是 JavaScript 任何这方面的支持都没有,这对开发大型的、复杂的项目形成了巨大障碍。在 ES6 之前,社区制定了一些模块加载方案,最主要的有 CommonJS 和 AMD 两种。

前者用于服务器,后者用于浏览器。ES6 在语言标准的层面上,实现了模块功能,而且实现得相当简单,完全可以取代 CommonJS 和 AMD 规范,成为浏览器和服务器通用的模块解决方案。

ES6 模块的设计思想是尽量的静态化,使得编译时就能确定模块的依赖关系,以及输入和输出的变量。CommonJS 和 AMD 模块,都只能在运行时确定这些东西。比如,CommonJS 模块就是对象,输入时必须查找对象属性。

// CommonJS模块
let { stat, exists, readFile } = require('fs');
// ES6模块
export { stat, exists, readFile };
import { stat, exists, readFile } from 'fs';


ES6 的模块功能主要由两个命令构成:exportimport。export命令用于规定模块的对外接口,import命令用于输入其他模块提供的功能。当然现在浏览器还不支持


模块规范(CommonJSAMDCMDUMD)


  1. CommonJS(NodeJS)


require引入模块是同步的,但script标签引入JS是异步的, 因此CommonJS在浏览器环境下无法正常加载(无法处理依赖问题)。


//模块定义 myModule.js
   var name = 'Byron';
   function printName(){
       console.log(name);
   }
   module.exports = {
       printName: printName,
   }
   //加载模块
   var myModule = require('./myModule.js');
   myModule.printName();


2.AMD(RequireJS)


AMD: Asynchronous Module Definition(异步模块定义)。AMD模块中所有的依赖都前置,require指定的回调函数,只有前面的模块都加载成功后,才会运行,解决了依赖性的问题。


// 定义模块 myModule.js
   //define([依赖的模块],定义模块的代码)
   define(function(){
       var name = 'Byron';
       function printName(){
           console.log(name);
       }
       return {
           printName: printName
       };
   });
   // 加载模块
   //require([依赖的模块],callback(依赖名))
   require(['myModule.js'], function (myModule){
     myModule.printName();
   });


3.CMD(SeaJS)


CMD: Common Module Definition(通用模块定义), 推崇依赖就近原则(也就是懒加载),模块内部的依赖在需要引入的时候再引入.


// 定义模块  myModule.js
define(function(require, exports, module) {
  var $ = require('jquery.js');
  var foo = require('foo');
  var out = foo.bar();
  $('div').addClass('active');
  module.exports = out;
});
// 加载模块
seajs.use(['myModule.js'], function(myModule){
});


4.UMD


UMD: 兼容AMD、CMD和commonJS规范的同时,还兼容全局引用的方式 例子:


//moduleName.js
   ;(function (global) {
       function factory () {
           var moduleName = {};
           return moduleName;
       }
       //CommonJS
       if (typeof module !== 'undefined' && typeof exports === 'object') {
           module.exports = factory();
       } else if (typeof define === 'function' && (define.cmd || define.amd)) { //AMD || CMD
           define(factory);
       } else { //script标签
           global.moduleName = factory();
       }
   })(typeof window !== 'undefined' ? window : global);
   UMD模块在不同环境引入:
   // Node.js
   var myModule = require('moduleName');
   // SeaJs
   define(function (require, exports, module) {
       var myModule = require('moduleName');
   });
   // RequireJs
   define(['moduleName'], function (moduleName) {
   });
   // Browse global
   <script src="moduleName.js"></script>


5.ES6模块(import,export)


可以取代CommonJS和AMD规范,是浏览器和服务器通用的模块解决方案。


//模块定义 myModule.js
   var name = 'Byron';
   function printName(){
       console.log(name);
   }
   const myModule = {
       printName: printName,
   };
   export myModule;
   //加载模块
   import myModule from './myModule.js';
   myModule.printName();


继承


js 中的继承依赖于 原型链继承。


function Fun(){};//声明一个方法
Fun.prototype.toAuthor = ()=>console.log('linong');//在他的原型上绑定一个方法
var fun = new Fun();//实例化一下
fun.toAuthor()//调用方法,
fun.toAuthor = ()=>console.log('lilnong.top');//覆盖这个方法
fun.toAuthor();//调用,这个时候在自己这里找到了,就不会去调用原型上的方法了
fun.__proto__ == Fun.prototype //实例上是__proto__ ,构造函数上是prototype

bVbsnzL.webp.jpg


后记


主讲人文章-2019.04.11


参考文献


  1. ECMAScript 6 入门
相关文章
|
2月前
|
JSON 缓存 前端开发
SpringBoot的 ResponseEntity类讲解(具体讲解返回给前端的一些事情)
本文讲解了SpringBoot中的`ResponseEntity`类,展示了如何使用它来自定义HTTP响应,包括状态码、响应头和响应体,以及如何将图片从MinIO读取并返回给前端。
136 3
|
2月前
|
前端开发
前端浮动模块
前端浮动模块
24 0
前端浮动模块
|
2月前
|
JSON 前端开发 JavaScript
前端模块打包器的深度解析
【10月更文挑战第13天】前端模块打包器的深度解析
|
2月前
|
前端开发
开发指南047-前端模块版本
平台前端框架内置了一个文件version.vue
|
3月前
|
前端开发 开发者
在前端开发中,webpack 作为一个强大的模块打包工具,为我们提供了丰富的功能和扩展性
【9月更文挑战第1天】在前端开发中,Webpack 作为强大的模块打包工具,提供了丰富的功能和扩展性。本文重点介绍 DefinePlugin 插件,详细探讨其原理、功能及实际应用。DefinePlugin 可在编译过程中动态定义全局变量,适用于环境变量配置、动态加载资源、接口地址配置等场景,有助于提升代码质量和开发效率。通过具体配置示例和注意事项,帮助开发者更好地利用此插件优化项目。
89 13
|
4月前
|
前端开发 安全 测试技术
[译]一种基于模块联邦的插件前端
[译]一种基于模块联邦的插件前端
|
4月前
|
前端开发 Java 编译器
【前端学java】java中的Object类和前端中的Object有什么区别(9)
【8月更文挑战第10天】java中的Object类和前端中的Object有什么区别
50 0
【前端学java】java中的Object类和前端中的Object有什么区别(9)
|
4月前
|
存储 前端开发 JavaScript
【前端学java】面向对象编程基础-类的使用(4)
【8月更文挑战第9天】面向对象编程基础-类的使用
28 0
|
4月前
|
开发框架 JSON 缓存
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理
|
4月前
|
前端开发
解锁CSS神秘面纱:深度剖析类选择器,掌握前端设计的绝密武器!
解锁CSS神秘面纱:深度剖析类选择器,掌握前端设计的绝密武器!