JavaScript编写学生查询系统
const readline = require('readline-sync')//引用readline-sync
//用户名,密码
let user = [{
username: 'yang',
password: 123
}, {
username: 'kai',
password: 456
}, {
username: 'ming',
password: 789
}
];
// 注册
let fn2 = function () {
console.log('请输入注册用户名:');
let username1 = readline.question();
console.log('请输入注册密码:');
let password1 = readline.question() - 0;
let obj = {};//创建对象
obj.username = username1;
obj.password = password1;
user.push(obj);//添加数据
console.log('注册成功,跳转登陆页面。。。。')
add();
// liuchen();
//调用登录
}
//登陆
let add = function () {
let s = 2;//错误的次数
while (true) {
console.log('请输入用户名:');
let username = readline.question();
console.log('请输入密码:');
let password = readline.question() - 0;
for (let i = 0; i < user.length; i++) {
if (username == user[i].username && password == user[i].password) {//判断输的值与初始值是否相等
console.log('欢迎你,登陆成功');
liuchen();//调用登陆后的主流程
return;
}
}
//输入不正确,超过三次
if (s != 0) {
console.log(`密码或账户有误,你还有${s}次机会,请重新输入!`);
s--;
} else {
console.log('账户锁定!');
break;
}
}
}
//登录前主流程
let fn3 = function () {
console.log('请选择以下要求:1.登陆 2.注册 3.退出');
let num = readline.question() - 0;//选择要求
switch (num) {
case 1:
add();//调用add
break;
case 2:
fn2();//调用注册
break;
case 3:
console.log('欢迎下次光临,再见!')
return;//结束
}
}
//查询所有
let arr = [
{ id: 1, name: 'liu', age: '18', gender: 'nan', score: '98' },
{ id: 2, name: 'li', age: '20', gender: 'nv', score: '80' },
{ id: 3, name: 'zhang', age: '20', gender: 'nv', score: '90' },
{ id: 4, name: 'ma', age: '21', gender: 'nan', score: '70' }
]
console.log('学号\t姓名\t年龄\t性别\t成绩\t');
for (let ai of arr) {//遍历出数组
let str = '';
for (let key in ai) {//遍历出键名
str += ai[key] + '\t';
}
console.log(str);
}
let maxID = 4;//给一个固定的值
//分类查询
let chaxun = function () {
while (true) {
console.log('请选择查询类型: 1.姓名 2.年龄 3.性别 4.成绩 5.返回');
let num3 = readline.question() - 0;
switch (num3) {
case 1:
console.log('请输入要查询的名字:');
fun('name');
break;
case 2:
console.log('请输入要查询的年龄:');
fun('age');
break;
case 3:
console.log('请输入要查询的性别:');
fun('gender');
break;
case 4:
console.log('请输入要查询的成绩:');
fun('score');
break;
case 5:
return;
}
}
}
let fun = function (type) {//type键名为变量要用[]
let name = readline.question();
for (let i in arr) {//模糊查找
if (arr[i][type].search(name) >= 0) {
console.log(arr[i]);
}
}
//第二种方法
// for (let i = 0; i < arr.length; i++) {//精确查找
// if (arr[i][type] == name) {
// console.log(arr[i]);
// }
// }
}
//查询
let chaxun1 = function () {
while (true) {
console.log('请选择查询方式:1.查询所有 2.分类查询');
let num2 = readline.question() - 0;
switch (num2) {
case 1://查询所有
for (let a of arr) {//遍历数组
console.log(a);
}
break;
case 2://分类查询
chaxun();
break;
}
break;
}
}
//新增
let xinzhen = function () {
while (true) {
console.log('请输入新增学生姓名:');
let name = readline.question();
console.log('请输入新增学生的年龄:');
let age = readline.question();
console.log('请输入新增学生的性别:');
let gender = readline.question();
console.log('请输入新增学生的成绩:');
let score = readline.question();
let arr1 = {};//创建对象
arr1 = ({ id: ++maxID, name, age, gender, score });
arr.push(arr1);//添加数据
console.log(arr1)
break;
}
}
//修改
let xiugai = function () {
while (true) {
console.log('请输入要修改学生的学号:');
let id = readline.question() - 0;
for (let i4 = 0; i4 < arr.length; i4++) {
if (arr[i4].id == id) {//判断输入的id名
console.log('当前学生信息如下:');
console.log(arr[i4])
console.log('请选择要修改的信息:1.姓名 2.年龄 3.性别 4.成绩 5.返回')
let num4 = readline.question() - 0;
switch (num4) {
case 1:
xiugai1(i4, 'name');
break;
case 2:
xiugai1(i4, 'age');
break;
case 3:
xiugai1(i4, 'gender');
break;
case 4:
xiugai1(i4, 'score');
break;
case 5:
return;
}
}
} break;
}
}
let xiugai1 = function (i4, xinxi) {//i4.为学生下标的属性,xinxi为要修改的键名(变量用[])
console.log('请输入新的数据:');
let name = readline.question();
arr[i4][xinxi] = name;//输入的信息赋值给键名
console.log('修改成功!该学生信息如下:');
console.log(arr[i4]);
}
//删除
let shanchu = function () {
while (true) {
console.log('请输入要删除学生的学号:');
let id1 = readline.question() - 0;
for (let i5 = 0; i5 < arr.length; i5++) {
if (arr[i5].id == id1) {//判断输入的id1是否等于对象的键名
console.log('当前学生信息如下:');
console.log(arr[i5]);
console.log('确定删除:1.是 2.否');
let num5 = readline.question() - 0;
if (num5 == 1) {
console.log('删除成功!删除后信息如下:');
arr.splice(i5, 1);//删除数据i为下标,1为删除的个数
for (let a of arr) {
console.log(a);
}
}
}
}
break;
}
}
//主控住流程
let liuchen = function () {
while (true) {
console.log('请选择一下操作:。。1.查询 2.新增 3.修改 4.删除 5.退出');
let num1 = readline.question() - 0;
switch (num1) {
case 1:
//查询
chaxun1();
break;
case 2:
// 新增
xinzhen();
break;
case 3:
//修改
xiugai();
break;
case 4:
//删除
shanchu();
break;
case 5:
//退出
console.log('欢迎下次使用,再见!');
return;
}
}
}
fn3();
JavaScript编写学生查询系统的更多相关文章
- java web知识点复习,重新编写学生选课系统的先关操作。
为了复习之前学习的相关的html,javaweb等知识.自己有重新编写了一遍学生选课系统. 下面主要展示登录界面的代码,以及各个大的主页面的相关jsp. <%@ page language=&q ...
- 暑假闲着没事第一弹:基于Django的长江大学教务处成绩查询系统
本篇文章涉及到的知识点有:Python爬虫,MySQL数据库,html/css/js基础,selenium和phantomjs基础,MVC设计模式,ORM(对象关系映射)框架,django框架(Pyt ...
- JAVA | 学生选课系统
这里使用JAVA语言编写的简易的学生选课系统,展现的都是这个系统核心代码. 其中有不足欢迎批评和指正! 链接数据库的代码 package connection;//连接数据库student impor ...
- C语言程序设计#成绩查询系统
学生成绩管理系统 [注释]:请点赞,好人一生平[yi]安[wo]. #codeblocks程序下编写 #include<stdio.h>#include<stdlib.h>// ...
- 用Javascript编写Chrome浏览器插件
原文:http://homepage.yesky.com/62/11206062.shtml 用Javascript编写Chrome浏览器插件 2010-04-12 07:30 来源:天极网软件频道 ...
- JavaScript编写了一个计时器
初学JavaScript,用JavaScript编写了一个计时器. 设计思想: 1.借助于Date()对象,来不断获取时间点: 2.然后用两次时间点的毫秒数相减,算出时间差: 3.累加时间差,这样就能 ...
- 【云图】如何制作全国KTV查询系统?
原文:[云图]如何制作全国KTV查询系统? 摘要:本文以[唱吧]531麦霸音乐节为案例,详细解读了如何导入自有数据到高德云图,并进行检索和展示.最后,调起高德mobile地图来进行路线规划和周边查询. ...
- 【百度地图API】建立全国银行位置查询系统(五)——如何更改百度地图的信息窗口内容?
原文:[百度地图API]建立全国银行位置查询系统(五)--如何更改百度地图的信息窗口内容? 摘要: 酷讯.搜房.去哪儿网等大型房产.旅游酒店网站,用的是百度的数据库,却显示了自定义的信息窗口内容,这是 ...
- 【百度地图API】建立全国银行位置查询系统(四)——如何利用百度地图的数据生成自己的标注
原文:[百度地图API]建立全国银行位置查询系统(四)--如何利用百度地图的数据生成自己的标注 摘要: 上一章留个悬念,"如果自己没有地理坐标的数据库,应该怎样制作银行的分布地图呢?&quo ...
随机推荐
- Vue使用html2Canvas和canvas2Image下载二维码会模糊的问题解决方法
// 下载二维码图片的方法 saveImg() { var self = this; html2canvas(document.querySelector(".savePic"), ...
- 须知的css——margin不重叠的情形
margin重叠 摘自css2.1规范中文版 CSS中,两个或者多个盒(可能但不一定是兄弟)的相邻的margin会被结合成一个margin.Margin按这种方式结合叫重叠(collapse),产生的 ...
- js 数据监听--对象的变化
class Observer { constructor(data) { this.data = data; this.filterObj(data); } static isObject(obj) ...
- 线性表的Java实现--链式存储(单向链表)
单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始. 链式存储结构的线性表将采用一组任意的存储单元存放线性表中的数据元素.由于不需要按顺序存储,链表在 ...
- 系统测试用例评审checklist
规则要素内容 使用范围 审查结果 “否”的理由 “免”的理由 规则 建议 是 否 免 规范性规则 用例是否按照公司规定的模板进行编写? √ 用例的 ...
- Redis(二):c#连接Redis
1.nuget StackExchange.Redis 2.建立RedisHelper类: public class RedisHelper { /// <summary> /// 连接字 ...
- 使用 Azure CLI 在 Azure China Cloud 云平台上手动部署一套 Cloud Foundry
这篇文章将介绍如何使用 Azure CLI 在 Azure China Cloud 云平台上手动部署一套 Cloud Foundry.本文的目的在于: 了解作为 PaaS 的 Cloud Foundr ...
- 利用.NET Core类库System.Reflection.DispatchProxy实现简易Aop
背景 Aop即是面向切面编程,众多Aop框架里Castle是最为人所知的,另外还有死去的Spring.NET,当然,.NET Core社区新秀AspectCore在性能与功能上都非常优秀,已经逐渐被社 ...
- JavaScript停止事件冒泡和取消事件默认行为
功能:停止事件冒泡 function stopBubble(e) { // 如果提供了事件对象,则这是一个非IE浏览器 if ( e && e.stopPropagation ) { ...
- 使用@selector模仿代理功能降低代码耦合度
使用@selector模仿代理功能降低代码耦合度 说明 该模式的好处就是两个产生联系的对象间并没有具体的耦合代码,增删改查均很直观 源码 Model // // Model.h // SELMetho ...