2017年6月1日木曜日

開発環境

Head First JavaScript Programming (Eric T. Freeman (著)、Elisabeth Robson (著)、O'Reilly Media)の Chapter 13.(Extra strength objects - Using Prototypes)の CODE MAGNETS(No. 8620)を取り組んでみる。

CODE MAGNETS(No. 8620)

コード(Emacs)

HTML5

<pre id="output0"></pre>
<button id="run0">run</button>
<button id="clear0">clear</button>
<script src="sample5.js"></script>

JavaScript

let btn0 = document.querySelector('#run0'),
    btn1 = document.querySelector('#clear0'),
    pre0 = document.querySelector('#output0'),
    p = (x) => pre0.textContent += x + '\n',
    range = (start, end, step=1) => {
        let result = [];
        for (let i = start; i < end; i += 1) {
            result.push(i);
        }
        return result;
    };

let Game = () => {
    let that = {},
        level = 0,
        unlocked = false;
        play = () => {
            level += 1;
            p(`Welcome to level ${level}`);
            unlock();
        },
        unlock = () => {
            if (level === 42) {
                unlocked = true;
            }
        };    
    
    that.play = play;
    that.getLevel = () => level;
    that.getUnlocked = () => unlocked;

    return that;
};

let Robot = (name, year, owned, game) => {
    let that = {},
        deployLaser = () => {
            if (game.getUnlocked()) {
                p(`${name} is blasting you with laser beams.`);
            }
        },
        toString = () =>
        `${name} was made by ObjectsRUs in ${year} and is owned by ${owned}`;

    that.toString = toString;
    that.deployLaser = deployLaser;
    
    return that;
};

let SpaceRobot = (name, year, owned, game, homePlanet) => {
    let that = Robot(name, year, owned, game),
        speak = () => 'speak',
        pilot = () => 'pilot';

    that.getHomePlanet = () => homePlanet;
    that.speak = speak;
    that.pilot = pilot;
    
    return that;
};

let output = () => {
    let game = Game(),
        robby = Robot('Robby', 1956, 'Dr.Morbius', game),
        rosie = Robot('Rosie', 1962, 'George Jetson', game),
        robby1 = SpaceRobot('Robby', 1956, 'Dr.Morbius', game, 'homePlanet1'),
        rosie1 = SpaceRobot('Rosie', 1962, 'George Jetson', game, 'homePlanet2');

    p(robby.getHomePlanet);
    p(robby.speak);
    p(rosie.pilot);

    p(robby1.getHomePlanet());
    p(robby1.speak());
    p(robby1.pilot());
    
    p(rosie1.getHomePlanet());
    p(rosie1.speak());
    p(rosie1.pilot());
};

let clear = () => pre0.textContent = '';

btn0.onclick = output;
btn1.onclick = clear;

output();





    







						

0 コメント:

コメントを投稿