如何写Node.JS版本小游戏

概述

今天就利用Node.JS为大家带来简单有趣的的剪刀石头布的小游戏。

打造流程

  • 引入模块
  • 定义简单石头布行为命令、当前局数(三局两胜)、得分情况、电脑随机出的行为(剪刀/石头/布)
  • 定义关联逐行读取流
  • 清屏
  • 打印开局提示信息
  • 监听line事件,根据读取流(用户输入)判断用户是要结束游戏,还是出招啦
  • 监听close 事件,如果玩够了3局就打印最终结果,否则直接结束进程
  • 定义scoreRule 方法,根据规则判断得分情况

相关api

先来看一看相关的API,我们按照调用顺序了解一下API,整个流程也就通啦

readline

逐行读取可读流中的数据

基础使用

  • readline.createInterface() 方法创建一个新的 readline.Interface 实例,定义关联的input 可读流和output 可写流,output 流可以读取input 流内容并输出打印提示。
  • `process.stdin` 和 `process.stdout` 对应进程的可读流和可写流。
  • readline.close() 调用方法,表示实例完成,放弃对input流和output流的控制,Game Over ~
  • process.exit([code]) 方法:终止node进程,code默认值是0,标识成功终止退出。不论是可读流的读取还是实例的完成事件,都需要我们来监听做点啥,要不然还有什么意义呢?
  • 监听line 事件:每当input 流接收到行尾输入(\n 、 \r 或者\r\n )时就会触发,也就是我们在node控制台按下Enter 或者 Return 键的时候,调用监听回调函数时携带可读流接收的字符串。

chalk

粉笔,node终端的样式库,修改终端输出字符串的颜色、加粗、隐藏以及背景色等样式

const chalk = require('chalk')
const logText = chalk.green(`
Hello,一起游戏吧!
`)
console.log(logText)

clear

清屏指令,node终端清屏,清除当前终端视图显示

这个使用起来最简单,在你需要清屏的地方执行一下clear() 方法就行了。

const clear = require('clear')
clear()

步骤补充说明

// 定义指令列表,
// 判断玩家输入的指令是否正确以及电脑的随机输出都从这里拿
const act = ['剪刀', '石头', '布']
// 根据读取流判断玩家输入信息
// 监听读取流输入
rl.on('line', function (input) {
 if (input === 'quit') {
   // 如果输入【quit】 执行close()方法
   rl.close()
 } else if (act.indexOf(input) !== -1) {
   // 如果输入字符串在指令列表内
   // 随机生成电脑的对应指令
   const idx = Math.floor((Math.random() * 3))
   gamer = act[idx]
   // 根据得分规则判断玩家是否得分
   const curScore = scoreRule(input, gamer)
   // 得分进行累计
   score += curScore

   // 打印本回合信息
   let win = curScore === 1 ? '本次玩家获胜' : curScore === -1 ? '本次电脑获胜' : '打平了,一定是巧合'
   result = `
   ※ ※ ※ ※ ※ ※ ※ ※ ※ ※
   第${num}回合:
   -------------------
   玩家出了: ${input}
   电脑出了: ${gamer}
   ${win}
   ※ ※ ※ ※ ※ ※ ※ ※ ※ ※
   `
   // 写入流后,继续下一回合
   num++;
   console.log(result)
   // 如果已经玩了3个回合,则执行close()方法
   if (num > 3) {
     rl.close()
   }
 } else {
   // 其他输入 打印正确的输入提示
   console.log(`
   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   继续游戏,请输入:【剪刀】、【石头】、【布】
   退出游戏,请输入: 【quit】
   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   `)
 }
})

完整代码

// stone.js
const readline = require('readline')
const clear = require('clear')
const chalk = require('chalk')

const act = ['剪刀', '石头', '布']
let num = 1
let score = 0
let gamer = ''
let result = ''

const rl = readline.createInterface({
 input: process.stdin,
 output: process.stdout
})

clear()

const beginText = chalk.green(`
============================================

开始游戏,请输入:【剪刀】、【石头】、【布】
退出游戏,请输入: 【quit】

============================================
`)
console.log(beginText)

rl.on('line', function (input) {
 if (input === 'quit') {
   rl.close()
 } else if (act.indexOf(input) !== -1) {
   const idx = Math.floor((Math.random() * 3))
   gamer = act[idx]
   const curScore = scoreRule(input, gamer)
   score += curScore

   let win = curScore === 1 ? '本次玩家获胜' : curScore === -1 ? '本次电脑获胜' : '打平了,一定是巧合'
   result = `
   ※ ※ ※ ※ ※ ※ ※ ※ ※ ※
   第${num}回合:
   -------------------
   玩家出了: ${input}
   电脑出了: ${gamer}
   ${win}
   ※ ※ ※ ※ ※ ※ ※ ※ ※ ※
   `
   num++;
   console.log(result)
   if (num > 3) {
     rl.close()
   }
 } else {
   console.log(`
   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   继续游戏,请输入:【剪刀】、【石头】、【布】
   退出游戏,请输入: 【quit】
   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   `)
 }
})

// 监听关闭 退出进程
rl.on('close', function () {
 if (num > 3) {
   winText = score > 0 ? '玩家获得了最终的胜利' : score < 0 ? '玩家最后还是输啦,加油哦' : '不可思议的平局'
   console.log(`
   ==========================
   本局结束,玩家总得分${score}
   ${winText}
   ==========================
   `)
 }
 process.exit(0)
})

function scoreRule(player, npc) {
 // 剪刀 布
 // 石头 剪刀
 // 布 石头
 if (player === npc) {
   return 0
 }
 if ((player === '剪刀' && npc === '布')
   || (player === '石头' && npc === '剪刀')
   || (player === '布' && npc === '石头')) {
   return 1
 } else {
   return -1
 }
}

抛砖引玉

node的学(mō)习(yú)的过程,我们会接触到越来越多的依赖模块和API,也从侧面说明了npm库的强大,我们想用的功能可能搜一搜就可以找到并且拿来用了。不要迷失在API的浪花中,我们了解到了,在用到的时候勿忘搜索技巧就好。

这里的【剪刀石头布】好lou啊(简直不能看),但是我们学习的过程可以始于lou,一lou一lou的深入下去,lou顶必将留下你精细的身影。欢迎吐槽我,欢迎深入node,加油~

以上就是如何写Node.JS版本小游戏的详细内容,更多关于Node.JS版本小游戏的资料请关注我们其它相关文章!

(0)

相关推荐

  • 如何利用nodejs实现命令行游戏

    目录 实现原理 源码解析 监听按键事件 绘制帧画面 蛇吃鸟蛋逻辑 总结 本文以贪吃蛇为例, 一步一步地分析如何实现一个命令行游戏. 实现原理 命令行输入 通过 process.stdin 监听命令行输入的按键, 改变小蛇的前进的方向 画面渲染 通过 ANSI 转义序列 擦除之前的输出 通过 process.stdout 每隔一段时间将画面帧输出到命令行 源码解析 监听按键事件 使用过 yarn upgrade-interactive 命令更新 npm 依赖, 或者使用过 vue-cli 等脚手架

  • node.js适合游戏后台开发吗?

    网站服务器和游戏服务器是怎么样联系到一起的? 1. 游戏分很多种,咱们先来看看MMORPG. 再怎么简单的RPG服务器都免不了处理多人交互的情形,上百人在同一个场景里面,每个客户端都需要收到其他所有人的操作信息. 其次,用户的操作是非常频繁的,一般的服务器倾向于持有长连接.而且这些链接的是频繁交互的,没有明显的持久的分区策略,所以限制了服务器的横向扩展,同一个场景往往只能放在一个物理机上面运行. 再次,端游通常是不敢把逻辑运算放客户端的,用户分分钟给你破解掉,改改金币,刷两件装备再常见不过了.所

  • NodeJS和浏览器中this关键字的不同之处

    前言 学习过JavaScript的人肯定清楚 处在不同环境下this的指向问题.那么看下面的代码 var type = 1 function toWhere(){ this.type = 2; } toWhere(); console.log(type) 你们肯定会这样想: 这里声明了一个全局变量type,当执行type=1的时候,赋值为1.之后toWhere函数调用,看到函数中有this 就去判断this的指向,这里很清楚,this指向了window,this.type=2执行后,全局变量ty

  • Nodejs实现多人同时在线移动鼠标的小游戏分享

    最近因为项目需要,所以研究了一下nodejs的websocket实现,socket.io,这是nodejs后台应用websocket广泛使用的框架. 准备工作 1.安装socket.io,使用命令npm install socket.io 2.windows系统的话,需要vc编译环境,因为安装socket.io的时候,会编译vc代码 游戏基本原理 1.服务器监听客户端的连接 2.客户端连接成功时候,绑定页面移动鼠标事件,事件里处理发送当前坐标给服务器 3.服务器保存一个全局的坐标对象,并以客户端

  • Node.js 制作实时多人游戏框架

    在 Node.js 如火如荼发展的今天,我们已经可以用它来做各种各样的事情.前段时间UP主参加了极客松活动,在这次活动中我们意在做出一款让"低头族"能够更多交流的游戏,核心功能便是 Lan Party 概念的实时多人互动.极客松比赛只有短得可怜的36个小时,要求一切都敏捷迅速.在这样的前提下初期的准备显得有些"水到渠成".跨平台应用的 solution 我们选择了node-webkit,它足够简单且符合我们的要求. 按照需求,我们的开发可以按照模块分开进行.本文具体

  • 使用Node.js实现一个多人游戏服务器引擎

    摘要 听说过文字冒险游戏吗? 如果你的年龄足够大的话(就像我一样),那么你可能听说过.甚至玩过"back in the day".在本文中,我将向你展示编写的整个过程.这不仅仅是一个文本冒险游戏,而是一个能让你和你的朋友们一起玩的,可以进行任何剧情的文本冒险游戏引擎. 没错,我们将通过在添加多人游戏功能来增加它的趣味性. 文字冒险是最早的 RPG 形式的游戏之一,回到还没有图形画面的时代,你只能通过阅读 CRT 显示器上黑色背景下的描述,并且依赖自己的想象力来推动游戏剧情的发展. 如果

  • Nodejs实现定时爬虫的完整实例

    事件起因 前两天要帮朋友B站舰长群审核,一个个去舰长列表查找,自然不是一个程序猿的首选,把任务交给计算机让他自己做,摸鱼才是正道.理论成立开始Coding . 由于已知舰长列表的 API 爬虫使用 Axios 直接访问接口 于是花了亿点点时间写完了这段爬虫我称之为bilibili-live-captain-tools 1.0 const axios = require('axios') const roomid = "146088" const ruid = "642922&

  • nodejs处理tcp连接的核心流程

    前几天和一个小伙伴交流了一下nodejs中epoll和处理请求的一些知识,今天简单来聊一下nodejs处理请求的逻辑.我们从listen函数开始. int uv_tcp_listen(uv_tcp_t* tcp, int backlog, uv_connection_cb cb) { // 设置处理的请求的策略,见下面的分析 if (single_accept == -1) { const char* val = getenv("UV_TCP_SINGLE_ACCEPT"); sing

  • 如何写Node.JS版本小游戏

    概述 今天就利用Node.JS为大家带来简单有趣的的剪刀石头布的小游戏. 打造流程 引入模块 定义简单石头布行为命令.当前局数(三局两胜).得分情况.电脑随机出的行为(剪刀/石头/布) 定义关联逐行读取流 清屏 打印开局提示信息 监听line事件,根据读取流(用户输入)判断用户是要结束游戏,还是出招啦 监听close 事件,如果玩够了3局就打印最终结果,否则直接结束进程 定义scoreRule 方法,根据规则判断得分情况 相关api 先来看一看相关的API,我们按照调用顺序了解一下API,整个流

  • JavaScript写个贪吃蛇小游戏(超详细)

    贪吃蛇大家都玩过,但你会制作嘛?听起来好像很难的样子,其实非常的简单,话不多说直接上代码 我们先把dom结构写出来 <div id="content"> <div id="snake"> <div class="box head"></div> <div class="box"></div> </div> </div> 其中,con

  • 利用n 升级工具升级Node.js版本及在mac环境下的坑

    一.利用n 升级Node.js 最近在用NPM安装一个nodejs工具时发现,我的nodejs的版本有些旧了.这不是大问题,只要升级就可以了,当然,重新从nodejs.org最新版本是一种方法,但我想应该有更简单的方法,那就是使用 n 这个工具包,我们可以使用NPM先安装 n 工具包,然后用它升级nodejs,十分的方便. sudo npm cache clean -f sudo npm install -g n sudo n stable 上面这是使用 n 来安装最新的稳定版的nodejs.

  • 使用Python第三方库pygame写个贪吃蛇小游戏

    今天看到几个关于pygame模块的博客和视频,感觉非常有趣,这里照猫画虎写了一个贪吃蛇小游戏,目前还有待完善,但是基本游戏功能已经实现,下面是代码: # 导入模块 import pygame import random # 初始化 pygame.init() w = 720 #窗口宽度 h = 600 #窗口高度 ROW = 30 #行数 COL = 36 #列数 #将所有的坐标看作是一个个点,定义点类 class Point: row = 0 col = 0 def __init__(self

  • 教你用Python写一个植物大战僵尸小游戏

    一.前言 上次写了一个俄罗斯方块,感觉好像大家都看懂了,这次就更新一个植物大战僵尸吧 二.引入模块 import pygame import random 三.完整代码 配置图片地址 IMAGE_PATH = 'imgs/' 设置页面宽高 scrrr_width = 800 scrrr_height = 560 创建控制游戏结束的状态 GAMEOVER = False 图片加载报错处理 LOG = '文件:{}中的方法:{}出错'.format(__file__, __name__) 创建地图类

  • Node.js搭建小程序后台服务

    准备条件 一台服务器 SSL证书,小程序规定必须要https协议 服务器后台 Node.js express mongodb pm2 下面以腾讯云主机(centos)为例 安装Node.js yum install nodejs 也可以安装nvm,用nvm管理nodejs版本 安装git yum install git 连接到远程代码库 以github为例: 配置用户信息 git config --global user.name youname git config --global user

  • node.js微信小程序配置消息推送的实现

    在开发微信小程序时,有一个消息推送,它的解释是这样的. 消息推送具体的内容是下面的这个网址   https://developers.weixin.qq.com/miniprogram/dev/framework/server-ability/message-push.html,他介绍的也还可以,就是我这里换成了node代码. 消息推送 启用并设置消息推送配置后,用户发给小程序的消息以及开发者需要的事件推送,都将被微信转发至该服务器地址中. 在微信小程序的首页开发里面,开发设置中,微信的官网中,

  • JS写的数字拼图小游戏代码[学习参考]

    复制代码 代码如下: <html> <head> <title>拼图</title> <style> td.numTd{ width : 20px ; height : 20px ; } div.numDiv{ width : 100% ; height : 100% ; background-color : #000 ; color : #FFF ; text-align : center ; vertical-align : middle ;

  • Luvit像Node.js一样写Lua应用

    luvit是什么?它是目前Lua这个小众语言中较为流行的一个开源框架,给那些习惯使用Lua的开发者一个机会向写Node.js一样用Lua进行开发,它是Lua的Node.js.在Gitlab上,项目的描述对于Luvit是这样描述的:Lua + libUV + jIT = pure awesomesauce. 概要信息 安装 提供了安装脚本进行一键安装,但是版本不是最新,如果需要最新的版本,可以从源码开始 curl -L https://github.com/luvit/lit/raw/master

  • js实现超级玛丽小游戏

    本文实例为大家分享了js超级玛丽小游戏的具体代码,供大家参考,具体内容如下 怎么用通过按键,来控制图片的位置 这个小游戏,用面向对象会很方便,不用面向对象会很麻烦很麻烦,比如以后要讲解的坦克大战的游戏,要是用纯的面向过程或函数式的方式写,那维护起来会非常的麻烦. 游戏分析: 看看如何通过按钮来控制mario的位置 设计相关的对象(Mario x y ...) onclick属性:当用户点击某个对象时调用的事件句柄 素材 代码在目录:超级玛利亚.html <html> <meta http

随机推荐