利用函数进行代码实现,要点:将每一项操作单独写成一个函数,在需要时进行调用,弄清参数的传递。
- 创建模拟账户
使用数组创建账户
let
user
= ["xiaohei",
1234,
500,
"xiaobai",
4321,
1000];
- 登录
//登录
function
login(userIndex)
{
while (n
>
0
&&
state) {
console.log(`>>>>请输入您的用户名:<<<<`);
let
inputName
=
rs.question();
if (user.includes(inputName)) {
//查找输入的用户名是否存在(正确)
//用户名正确,输入密码
console.log(`>>>>请输入密码:<<<<`);
let
inputPWD
=
rs.question() -
0;
if (inputPWD
==
user[user.indexOf(inputName) +
1]) {
//判断密码是否正确
//密码正确,调用主题函数(执行操作)
main(user.indexOf(inputName));
}
else
{
//密码不正确
//密码错误
n--;
if (n
!=
0) {
console.log(`密码错误,你还有${n}次机会!`);
}
else
{
console.log(`密码错误,您的账户被冻结!`);
state
=
false;
break;
}
}
}
else
{
//用户名不正确
n--;
if (n
!=
0) {
console.log(`用户名错误,你还有${n}次机会!`);
}
else
{
console.log(`用户名错误,您的账户被冻结!`);
state
=
false;
break;
}
}
}
}
函数需要调用才会实现,在代码的最后进行调用,避免出现先使用后声明的问题。
login()
登录成功后,调用主函数
//密码正确,调用主题函数(执行操作)
main(user.indexOf(inputName));
- 选择要进行的操作
在主函数中,选择要进行的操作,在每一项操作中调用对应的函数体
//主体
function
main(userIndex)
{
console.log(`登录成功!`);
state1
=
true;
while (state1) {
//开始选择需要的操作
、查询 2、存钱 3、
取钱 4、转账 5、切换账户 0、退出`);
let
choice
=
rs.question() -
0;
switch (choice) {
case
0:
console.log(`Thankyou fou your welcom!`);
state
=
false;
state1
=
false;
break;
case
1:
console.log(`您当前账户余额为${user[userIndex+2]}`);
break;
case
2:
saveMoney(userIndex);
break;
case
3:
dropMoney(userIndex);
break;
case
4:
console.log(">>>>请输入您要转账的账户:<<<<");
let
targetName
=
rs.question();
let
transIndex
=
searchName(targetName);
//获取转账账号的下标
if ((transIndex
||
transIndex
==
0) &&
transIndex
!=
userIndex) {
transMoney(userIndex,
transIndex);
}
break;
case
5:
let
temp=changename(userIndex);
userIndex=temp;
break;
default:
console.log(`您操作有误,请重新选择`);
state
=
false;
break;
}
}
}
- 0、退出
退出整个程序,结束所有循环,我的方法是在循环外let一个状态值
case
0:
console.log(`Thankyou For Your Welcome!`);
state1
=
false;
state
=
false;
break;
- 1、查询余额
不用单独 写成函数,只需输出余额即可
case
1:
console.log(`您查询的账户余额为${balance_1}`);
break;
输出时使用字符串模板,方便语句中变量的输出
- 2、存钱
//存钱
function
saveMoney(savename)
{
console.log(`>>>>请输入您要存入的金额:<<<<`);
let
saveMoney
=
rs.question() -
0;
user[savename
+
2] +=
saveMoney;
}
- 3、取钱
要点是要判断取出的金额是否小于余额
//取钱
function
dropMoney(dropname)
{
console.log(`>>>>请输入您要取出的金额:<<<<`);
let
dropMoney
=
rs.question() -
0;
if (dropMoney
<=
user[dropname
+
2
&&
dropMoney
>=
0]) {
user[dropname
+
2] -=
dropMoney;
}
else
{
console.log(`您当前账户余额不足!`);
}
}
- 4、转账
首先判断要转账的账户是否存在,
case
4:
console.log(">>>>请输入您要转账的账户:<<<<");
let
targetName
=
rs.question();
let
transIndex
=
searchName(targetName);
//获取转账账号的下标
if ((transIndex
||
transIndex
==
0) &&
transIndex
!=
userIndex) {
transMoney(userIndex,
transIndex);
}
break;
//查找账户是否存在
function
searchName(name)
{
if (user.includes(name)) {
return
user.indexOf(name);
//如果存在,返回下标,这样才可以进行后期的操作(余额)
}
else
{
console.log("您输入的账号不存在!!!");
return
false;
// break;
state1=false;
}
}
其次判断转账的金额是否小于余额
//转账
function
transMoney(currentName,
transName)
{
//currentName当前账户的下标,transName账户的下标
console.log("请输入您要转账的金额:");
let
targetMoney
=
rs.question() -
0;
if (targetMoney
<=
user[currentName
+
2]) {
//判断当前账户的余额是否大于转账的金额
user[currentName
+
2] -=
targetMoney;
//currentName + 2当前账户的余额
user[transName
+
2] +=
targetMoney;
//transName + 2当前账户的余额
}
else
{
console.log(`您的余额不足!!!`);
}
}
- 5、切换账户
//切换账户
function
changename(currentName,
changeName)
{
//currentName当前账户的下标,changeName切换账户的下标
console.log(`>>>>请输入切换的账户:<<<<`);
let
inputchangeName
=
rs.question();
let
changeIndex
=
searchName(inputchangeName);
//获取切换账号的下标
if ((changeIndex
||
changeIndex
==
0) &&
changeIndex
!=
userIndex) {
console.log(`>>>>请输入密码:<<<<`);
let
changePWD
=
rs.question() -
0;
if (changePWD
==
user[changeIndex
+
1]) {
//判断密码是否正确
return
changeIndex;
}
else
{
console.log(`密码错误`);
}
}
else
{
console.log(`账号错误`);
}
}
将获得的切换的下标与原账户下标交换
case
5:
let
temp=changename(userIndex);
userIndex=temp;
break;
切换后会重新登录。
以上为使用函数编写ATM系统的方法。重点在于将函数单独写出,调用时注意参数的传递。