相信大家都玩过一种网页游戏,通俗的可以叫颜色分辨测试游戏(这个名字对不对我也不知道,不要在意这些细节),也就是下面截图这个玩意,一看就明白;细细把玩过一段时间,作为一个一百米开外男女不分的弱视青年,每每过不了几关就挂了,对这个结局我也是异常无语,都怪当初学习太用功了(呵呵),想挑战的点击这里

  这个游戏的流程就是页面上会出现不同颜色的格子,也就是div啦,点击颜色唯一的格子就算过关,然后格子变多(max后不再变多),颜色变的相近,难度也就变大了,直到点错了或者倒计时结束了,很简单的样子,作为前端人员后不犹豫的F12之,如下:

  就是这个结构啦,#box中一串span,其中有个span的style:background是唯一的,点击这个唯一的就OK啦,于是我就顺其自然的想用脚本代替我逐个点击,没办法视力不行啊,还想省力,于是直接码之如下:

//取到所有background
var stylelist = new Array();
$("#box span").each(function() {
for(var i = 0; i < $("#box span").length; i++) {
stylelist[i] = $(this).attr("style");
}
});
//分割数组
var s = stylelist.join(",") + ",",
copy;
for(var i = 0; i < stylelist.length; i++) {
//取出唯一style
if(s.replace(stylelist[i] + ",", "").indexOf(stylelist[i] + ",") > -1) {
copy = stylelist[i];
}
}
//不解释了吧
$("#box span").each(function() {
if($(this).attr("style") != copy)
$(this).click();
return;
});

  然后上面的代码就可以代替手动点击了,很方便有木有,下面是我实测运行的结果:(如果有纯手点的记录超过我这个的,请收下我的膝盖)

  168关,你没有看错,就是168,一分钟时间通过168关,而且中间有浏览器反应的缓慢时间,所以真实的应该比这个还要高(开始有点理解游戏外挂了啊喂),但是这段代码太粗糙了(span少可以秒),效率很低,这个后面会继续说;

  如果有人问,桥豆麻袋~你是怎么运行的,浏览器上运行?这就说明你很少用浏览器调试啊,方法如下:

  简单粗暴直接运行就行了,当然这也不是最优的选择,因为每次到新关卡(新页面)都要手动去运行,也着实累手(回车键一脸委屈),可以考虑封装成浏览器插件,页面进来就自动运行了,省心省力~~

  接着上面所的效率说,来优化这段代码,之所以说这段代码粗糙,是因为它是遍历所有span,这里是不多所以几乎是秒过,如果是span很多或者性能要求极致的大厂,这段代码是通不过的,优化的方案就是遍历所有的span的style的时候,第一次遇到唯一style就操作了,比如有10000个格子,第十个就是不同的格子,所以只要遍历到这里就结束了,而不是遍历10000,不然浏览器君表示扛不住啊。。。话不多说码之如下:

var stylelist = new Array(),
copy;
$("#box span").each(function() {
for(var i = 0; i < $("#box span").length; i++) {
stylelist[i] = $(this).attr("style");
//初始格子数大于2
for(var j=0;j<stylelist.length;j++){
if(stylelist.toString().replace(stylelist[j],"").indexOf(stylelist[j])>-1){
copy = stylelist[j];
}
return;
}
}
});
//这里不知道还能不能优化,先mark一下
$("#box span").each(function() {
if($(this).attr("style") != copy)
$(this).click();
return;
});

  好吧,其实顺起来看很简单,然而实现容易,最优不易,极致的优化要求对于编写者是个十足的考验,毕竟写的都是经验积累啊,今天先码到这里吧,文中如有纰漏或更好的方法欢迎小伙伴们指出。

-------------------------------------脑袋被门夹后的华丽分割线------------------------------------------------

  果然手动操作是个愚蠢至极的方式啊,一直怀疑click那里有问题,没有注意到页面没刷新(以页面刷新的角度思考的,所以才提到浏览器插件 汗),刚刚一位小伙伴从头_再来给出这个思路,使用setTimeout自动循环,解决了这个问题,赞啊,厉害了word哥,受教,下面是跑分,完爆168

  

  代码如下,小伙伴们共同鉴赏:

(function findSpan(){
var spanList=document.getElementById("box").children,
spanLen=spanList.length; if(spanLen==0){
return;
} function getColor(index){
return spanList[index].style.backgroundColor;
} function isDiffSpan(index){
return getColor(index)!=getColor((index+1)%spanLen)
&& getColor(index)!=getColor((index+2)%spanLen);
} for(var i=0;i<spanList.length;i++){
if(isDiffSpan(i)){
spanList[i].click();
break;
}
} setTimeout(findSpan,10);
})();

  

  最后根据小伙伴的提示稍稍改动了下我的代码,可以跑7000左右,暴力了(跑的网页秒表都动不了。。。),不过隐隐感觉click那里还有问题,先放出这一版修改:

  

(function autoFind() {
var stylelist = new Array(),
copy;
$("#box span").each(function() {
for(var i = 0; i < $("#box span").length; i++) {
stylelist[i] = $(this).attr("style");
for(var j = 0; j < stylelist.length; j++) {
if(stylelist.toString().replace(stylelist[j], "").indexOf(stylelist[j]) > -1) {
copy = stylelist[j];
}
return;
}
}
});
$("#box span").each(function() {
if($(this).attr("style") != copy)
$(this).click();
return;
});
setInterval(autoFind, 10);
})()

  有想继续挑战的小伙伴可以尝试破了这个记录

网页颜色分辨测试小游戏的js化辨别及优化的更多相关文章

  1. 微信小游戏 three.js jsonloader request:fail invalid url

    微信小游戏中,用 THREE.JSONLoader 直接加载本地的 json 文件,报错.估计是跨域访问的问题 解决:把 json 文件放到服务器上,通过 url 来访问. 临时测试的话,在本地起一个 ...

  2. 微信小游戏 Three.js UI 2D text 简单方案

    在微信小游戏中使用 THREE.js 引擎,没有合适的 UI 库可用,只能自己动手.图片啥的都还好,text 不好弄.text 要计算 width 和 height,不然事件响应范围不对. funct ...

  3. 用原生JS写一个网页版的2048小游戏(兼容移动端)

    这个游戏JS部分全都是用原生JS代码写的,加有少量的CSS3动画,并简单的兼容了一下移动端. 先看一下在线的demo:https://yuan-yiming.github.io/2048-online ...

  4. 观摩制作小游戏(js应用)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 微信小游戏 main.js没有被压缩

    发布时,发现main.js没有被压缩. 在config.wxgame.ts里增加如下图.

  6. 玄机网C#论坛测试小游戏

    http://files.cnblogs.com/ro4ters/EasyGame.zip http://www.xuanjics.com/thread-39-1-1.html 具体活动地址

  7. HTML5小游戏源码收藏

    html5魅族创意的贪食蛇游戏源码下载 html5网页版打砖块小游戏源码下载 html5 3D立体魔方小游戏源码下载 html5网页版飞机躲避游戏源码下载 html5三国人物连连看游戏源码下载 js ...

  8. 微信小程序の微信js

    一.Javascript简介 二.nodejs中的jscript nodejs表示谷歌基于v8引擎的一门后端语言, ECMA表示ECMA262标准的基本js,native表示nodejs本身的一些包, ...

  9. 小游戏专场:腾讯云Game-Tech技术沙龙上海站顺利落下帷幕

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯游戏云发表于云+社区专栏 9月14日腾讯云GAME-TECH技术沙龙小游戏专场在上海顺利举办,此次技术沙龙由腾讯云的资深专家,以及 ...

随机推荐

  1. CodeIgniter2.2.0-在控制器里调用load失败报错的问题

    报错如下: hello A PHP Error was encountered Severity: Notice Message: Undefined property: Test::$load Fi ...

  2. MongoDB for C#基础入门

    笔者这里采用的是mongoDB官网推荐使用.net驱动: http://mongodb.github.io/mongo-csharp-driver/2.0/getting_started/quick_ ...

  3. 【WPF】分享自用 白板窗口(空窗口) 控件 BlankWindow,基于WindowChrome。

    一.背景 吃产品的亏,上设计的当,最后死在变化上. 现在的产品和设计都喜欢在窗口上做一些事,比如让Title做很多事,好像跟人家用一样的窗口很Low似的,好像真的挺Low的. 所以,还不如弄一个黑板似 ...

  4. SQL SERVER 2012 只能识别20个CPU的问题

    背景 最近在给客户优化时时候发现客户的虚拟机环境分配了32C 但是只能识别20个,物理机64C,64G内存,本来没什么,CPU利用率在40%左右,但是优化后同时增加了 CPU和内存的分配,CPU32增 ...

  5. 《C#图解教程》读书笔记之二:存储、类型和变量

    本篇已收录至<C#图解教程>读书笔记目录贴,点击访问该目录可获取更多内容. 一.类型初窥:掀起你的盖头来 (1)C程序是一组函数和数据类型,C++程序是一组函数和类,而C#程序是一组类型声 ...

  6. 【译】用Fragment解决屏幕旋转(状态发生变化)状态不能保持的问题

    这篇文章解决了在StackOverflow上一个经常被提到的问题. 在配置发生变化(Configuration changs)时,什么是最好的保存活动对象方法,比如运行中的线程,Sockets,Asy ...

  7. Oracle存在修改,不存在插入记录

    接触编程以来,在数据存储方面一直用的MS SQL.Oracle这名字对我来说是如此的熟悉,但是对其内容却很陌生,最近公司的一个项目用起了Oracle,所以也开始高调的用起了Oracle.在没有接触Or ...

  8. 用DirectX实现魔方(三)视角变换及缩放(附源码)

    在本系列第一篇介绍过鼠标按键的功能,如下. 左键拖拽 - 旋转魔方 右键拖拽 - 变换视角 滚轮 - 缩放魔方 今天研究一下如何实现后面两个功能,用到的技术主要是Arcball,Arcball是实现M ...

  9. Javascript函数节流

    最近在做网页的时候有个需求,就是浏览器窗口改变的时候需要改一些页面元素大小,于是乎很自然的想到了window的resize事件,于是乎我是这么写的 <!DOCTYPE html> < ...

  10. webservice2

    按照 当然,里面没写清楚如何配置第三方jar 结果一访问就报错:org.codehaus.xfire.transport.http.XFireConfigurableServlet 4年前就搞过ws的 ...