JavaScript 实现 Konami Code

我家的奶牛儿

我家的奶牛儿

2016-02-19 14:37

今天给大家分享的是由图老师小编精心为您推荐的JavaScript 实现 Konami Code,喜欢的朋友可以分享一下,也算是给小编一份支持,大家都不容易啊!

在 Facebook 上有一个彩蛋:

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

登录 facebook.com ,点击你首页的任何地方,键盘输入 Up, Up, Down, Down, Left, Right, Left, Right, B, A, Enter 后,再点击页面或滚动一下滚动条,你会发现特殊的变化(如下图),嘿嘿 ^^

JavaScript 实现 Konami Code

玩过“魂斗罗”的朋友,肯定一眼就能看出输入的字符原来就是“魂斗罗”中的“秘技”。其实“秘技”的术语叫 Konami Code,详细见图示:

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

JavaScript 实现 Konami Code

那如何用 JavaScript 也在自己的页面上添加一个类似的彩蛋呢?

Abhi 在 《Konami Code on Facebook : How to implement it on your site》 一文中提供了大体思路:

var $ = {
    enabled: false,
    tmp: Array(),
    _konamiCode: Array(65,66,39,37,39,37,40,40,38,38),
    init: function() {
        this.tmp = Array(65,66,39,37,39,37,40,40,38,38);
    },
    konamiCode: function(e) {
        if(!this.enabled) {
            var t = this.tmp.pop();
            if((e.keyCode-t) == 0) {
                if(this.tmp.length == 0) {
                    this.enabled = true;
                }
            } else {
                this.init();
            }
        } else {
            this.action();
        }
    },
    // Change the action() function to whatever you want to
    action: function() {
        //alert("Konami Code Activated");
    }
}

然后在 load 的时候调用 $.init() 方法,在 keydown 的时候调用 $.konamiCode(event) 方法。

不过 Abhi 的方法还是冗余了点,Jan Jarfalk 在留言中提供了一个短小精悍的代码:

// Tweetable Konami code
var k=[];
function(e){
    k.push(e.keyCode);
    if(k.toString().indexOf("38,38,40,40,37,39,37,39,66,65")=0) {
        //alert("Konami Code Activated");
    }
}

PS:有兴趣的还可以在 Google Reader 上尝试下此“秘技”,一般人我还不告诉他,嘿嘿。

展开更多 50%)
分享

猜你喜欢

JavaScript 实现 Konami Code

Web开发
JavaScript 实现 Konami Code

JavaScript实现Iterator模式

Web开发
JavaScript实现Iterator模式

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

Javascript trim()函数实现

Web开发
Javascript trim()函数实现

单行Javascript实现Memoization

Web开发
单行Javascript实现Memoization

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

Javascript实现的分页函数

Web开发
Javascript实现的分页函数

javascript实现页面淡出效果

Web开发
javascript实现页面淡出效果

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

jquery checkbox全选反选效果代码

jquery checkbox全选反选效果代码

如何在Linux中安装虚拟化工具llibvirt

如何在Linux中安装虚拟化工具llibvirt
下拉加载更多内容 ↓