成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

ES2015入門系列11-模塊 Modules

HitenDev / 743人閱讀

摘要:先來介紹下語法官方示例代碼模塊中對象暴露只需要即可,可以是任何類型的對象。手動導(dǎo)入模塊下某個對象,需要和模塊中定義的名字對應(yīng),順序無關(guān)。

看一下官方介紹:

Language-level support for modules for component definition.

JS在ES2015開始原生支持模塊化開發(fā),我們之前也曾借助于諸如:

AMD

CommonJS

等的模塊加載器進行過模塊化開發(fā),我想說的是那些都沒有今天要講的簡單好用。

?? 警告,正式版中的ES2015中沒有模塊加載器,所以我們依然需要之前的模塊加載器幫助我們。

先來介紹下語法(官方示例代碼):

//lib/math.js
export function sum(x, y) {
  return x + y;
}
export var pi = 3.141593;

//app.js
import * as math from "lib/math";
import {sum, pi} from "lib/math";
console.log("2π = " + math.sum(math.pi, math.pi));

模塊中對象暴露

只需要 export xx 即可,可以是任何類型的對象。

從模塊中導(dǎo)入

使用 import 即可, 幾種方式

import * as xx from ..

導(dǎo)入某個模塊下的所有到某個命名空間下,如示例代碼中的 import * as math from "lib/math", 意即將lib/math下所有暴露的對象導(dǎo)入到math對象下,之后就可以只用math.xxx訪問了。

import {x, y, z} from ..

手動導(dǎo)入模塊下某個對象,x, y, z 需要和模塊中定義的名字對應(yīng),順序無關(guān)。

略微有點啰嗦了是吧?來看下面這種:

//lib/math.js
export default function (x, y) {
  return x + y;
}
//app.js
import sum from "lib/math";

這樣以來,寫法上簡單了許多,如果有default,也有其他的export怎么辦呢?如下:

import default, {other1, other2} from "someMoule";

一般在開發(fā)中,只暴露一個default的情況占大多數(shù)。

還有一個叫 export *, 用來在某個模塊內(nèi)將另一個模塊的暴露的對象在這個模塊重新暴露出去,個人覺得用處不是很大,不做過多描述。

下面,我們繼續(xù)實戰(zhàn),依然是在ES2015入門系列10-類 classes中寫的游戲,我們是在一個文件里運行的,下面我們將代碼進行分拆成幾個文件,進入模塊化開發(fā):

使用ES2015入門系列9-Babel和Rollup的配置,我們的目錄結(jié)構(gòu)如下:

es2015-learning

dist

src

Game.js

Hero.js

main.js

Monster.js

Role.js

Game.js 代碼

import Monster from "./Monster.js";
import Hero from "./Hero.js";

export default class Game { //游戲世界

  constructor() {
    this.name = "權(quán)利的游戲";
    this.hero = new Hero("Jon Snow", 10); // 初始化英雄Jon Snow
    this.monsters = [ //怪物集合,模擬簡單的游戲關(guān)卡。
      new Monster("異鬼 01", 1, 10),
      new Monster("異鬼 02", 3, 30),
      new Monster("異鬼 03", 5, 50),
      new Monster("異鬼 04", 10, 100),
      new Monster("異鬼 05", 15, 150),
      new Monster("異鬼 06", 20, 200),
      new Monster("Night King", 50, 500)
    ];
    this.level = 0; // 游戲當前關(guān)卡記錄
    console.log(`你在[${this.name}]中扮演[${this.hero.name}], 征程即將開始...`);
  }

  play() { // 游戲開始
    while (this.level < this.monsters.length && ! this.hero.isDead()) {
      let monster = this.monsters[this.level];
      console.log(`關(guān)卡[${this.level + 1}] 你遇到了[${monster.name}], 進入戰(zhàn)斗:`);
      let offensive = this.hero;
      let defensive = monster;
      while (! this.hero.isDead() && ! monster.isDead()) {
        offensive.attack(defensive);
        let middleman = offensive;
        offensive = defensive;
        defensive = middleman;
      }
      if (this.hero.isDead()) {
        console.log(`你被[${monster.name}]打敗了, 游戲結(jié)束!`);
        break;
      }
      if (monster.isDead()) {
        console.log(`你打敗了[${monster.name}] 等級提升:[${monster.level}]`);
        this.hero.levelUp(monster.level);
        this.level ++;
      }
    }
    if (this.level === this.monsters.length) {
        console.log(`恭喜你通關(guān)游戲!`);
    }
  }

}

Hero.js 代碼

import Role from "./Role.js";

export default class Hero extends Role {

    attack(role) { //攻擊,有概率是用必殺攻擊
        if (! this.isCriticalStrike()) {
            return this.criticalStrike(role);
        }

        return this.strike(role);
    }

    criticalStrike(role) { //必殺攻擊
        let power = parseInt(200 * Math.random() + 50);
        role.damage(power);
        console.log(`[${this.name}]使用必殺攻擊了[${role.name}], 造成了[${power}]點傷害`);
    }

    isCriticalStrike() {
        return Math.random() > 0.70;
    }

}

Monster.js 代碼

import Role from "./Role.js";

export default class Monster extends Role {

}

Role.js 代碼

export default class Role { //角色基類

  constructor(name, level = 1, health = 100) {
      this.name = name;
      this.level = level;
      this.health = health;
  }

  isDead() { //判斷角色是否死亡
    return this.health <= 0;
  }

  levelUp(level = 1) { //升級
    this.level += level;
  }

  damage(power) { //受到傷害
    this.health = this.health - power;
  }

  attack(role) { //攻擊
    this.strike(role);
  }

  strike(role) { //普通攻擊
    let power = parseInt(Math.random() * 20 * this.level / 10);
    role.damage(power);
    console.log(`[${this.name}]攻擊了[${role.name}], 造成了[${power}]點傷害`);
  }

}

最后, main.js 代碼

import Game from "./Game.js";

new Game().play();

一切準備就緒,執(zhí)行:

npm run build

將編譯后的dist/main.js,放入網(wǎng)頁中,運行,Yeah!It works!

恭喜,我們一起學(xué)會了ES2015帶給我們的模塊化開發(fā)!

Keep on hacking!

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/83759.html

相關(guān)文章

  • ES2015入門系列9-Babel和Rollup

    摘要:雖然夠好用,奈何沒有瀏覽器對其可以完全支持,本文書寫時間,開發(fā)版號稱已經(jīng)支持的特性。開始安裝本系列假定讀者都有使用經(jīng)驗,如果還沒有,趕緊去這里了解并安裝吧。到此,我們的已經(jīng)準備就緒。 通過前面章節(jié)的講解,大家對ES2015的一些新語法有了初步的理解,之前我們的測試代碼都可以直接放入 Chrome Console 中直接運行,為了更好的學(xué)習后面的面向?qū)ο蠛湍K開發(fā),我先用一章介紹一下 B...

    eccozhou 評論0 收藏0
  • Babel快速入門

    摘要:首先,作為入門的話,的用戶手冊是個很不錯的選擇,里面基本覆蓋了使用的各方面。所以下面主要是我學(xué)習的一些筆記,姑且當作是一篇入門吧。下面我們正式進入正題。這也是最常用的一個用法之一。有兩個方式進行配置。 首先,作為入門的話,Babel的用戶手冊是個很不錯的選擇,里面基本覆蓋了Babel使用的各方面。所以下面主要是我學(xué)習Babel的一些筆記,姑且當作是一篇入門吧。 Babel是什么 按照B...

    notebin 評論0 收藏0
  • 讓 Angular 1.x 跟上時代的步伐

    摘要:所以說的模塊機制沒有解決文件依賴關(guān)系和文件異步加載的問題。大部分團隊還是停留在第二第三階段,每個階段的實現(xiàn)都有很多種選擇。希望這篇文章能夠激起大家永遠保持積極向前追求完美代碼的心,不僅對自己的成長也會對公司帶來無限的價值。 本篇技術(shù)博客來自有著化腐朽為神奇能力的,Worktile 技術(shù)牛人Web 總監(jiān) @徐海峰 大神的分享~滿滿的干貨,你值得擁有! Worktile 的前端構(gòu)建之路 2...

    李增田 評論0 收藏0
  • babel6 入門-配置安裝使用_byKL

    摘要:入門什么是是一個廣泛使用的轉(zhuǎn)碼器,可以將代碼轉(zhuǎn)為代碼,從而在現(xiàn)有環(huán)境執(zhí)行。 babel6 入門 什么是babel Babel是一個廣泛使用的轉(zhuǎn)碼器,可以將ES6代碼轉(zhuǎn)為ES5代碼,從而在現(xiàn)有環(huán)境執(zhí)行。 因為es6比es5的代碼更為適合編寫程序,但是因為歷史的原因,現(xiàn)在普遍的瀏覽器并不支持es6代碼(普遍支持es5),即如果你寫es6代碼之后,在瀏覽器上運行出錯,因為瀏覽器的javas...

    qianfeng 評論0 收藏0

發(fā)表評論

0條評論

HitenDev

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<