HTML+CSS+JS+Django 实现前后端分离的科学计算器、利率计算器

news2024/11/15 21:38:12

🧮前后端分离计算器

  • 📚git仓库链接和代码规范链接
  • 💼PSP表格
  • 🎇成品展示
    • 🏆🏆科学计算器:
      • 1. 默认界面与页面切换
      • 2. 四则运算、取余、括号
      • 3. 清零Clear 回退Back
      • 4. 错误提示 Error
      • 5. 读取历史记录History 历史记录的显示、隐藏
      • 6. 科学计算
      • 7. Ans的处理与计算
    • 🏆🏆利率计算器
      • 8. 存贷款--利息 计算
      • 9. 存贷款--利率表 修改
      • 10 数据库展示
  • 🚌设计实现过程
    • 1. 页面原型设计
    • 2. 前置知识学习
    • 3. 正式编码实现
  • 💻代码说明
    • 1. ajax 中get和post区别
    • 2. 隐藏标签的设置
    • 3. 点击按钮实现页面切换
    • 4. 判断select是否被选中并获取select选中的值
  • 😊心路历程和收获

本次作业完成了 全部的基础功能和附件功能1. 前端修改利率表 2. 科学计算 3. 页面原型设计 以及扩展功能1. 动态按钮,动态背景,页面局部or全局切换等等。

这个作业属于哪个课程< 2301-计算机学院-软件工程>
这个作业要求在哪里< 软工实践第二次作业>
这个作业的目标< 实现一个科学计算器具备的基本功能,并且UI设计较美观 >
其他参考文献< Django框架的使用 Web开发技术入门>

📚git仓库链接和代码规范链接

gitcode仓库链接

代码规范链接

💼PSP表格

PSPPersonal Software Process Stages预估耗时(分钟)实际耗时(分钟)
Planning计划3060
• Estimate• 估计这个任务需要多少时间3060
Development开发18002160
• Analysis• 需求分析 (包括学习新技术)300360
• Design Spec• 生成设计文档4060
• Design Review• 设计复审6080
• Coding Standard• 代码规范 (为目前的开发制定合适的规范)10060
• Design• 具体设计80100
• Coding• 具体编码9001000
• Code Review• 代码复审200260
• Test• 测试(自我测试,修改代码,提交修改)120240
Reporting报告190230
• Test Repor• 测试报告120150
• Size Measurement• 计算工作量1010
• Postmortem & Process Improvement Plan• 事后总结, 并提出过程改进计划6090
合计20202450

🎇成品展示

🏆🏆科学计算器:

1. 默认界面与页面切换

我们进入到界面的时候时科学计算器,因此我们需要设计一个合理的页面切换按钮,便于用户在页面中进行不同计算器的切换,以及在编辑利率表的时候对利率表的动态展示
在这里插入图片描述

2. 四则运算、取余、括号

四则运算时基本的加减乘除是根本所在,因此至关重要,我在后端用python实现这些计算。
在这里插入图片描述

3. 清零Clear 回退Back

撤销一位数字or算符:需要同时对显示表达式和计算表达式同时更新,并且显示表达式每次不是只撤回一个字符。因为(sin,cos,tan,log等多个字符表示的算符需要一次撤销几个字符,需要特殊处理)
在这里插入图片描述

4. 错误提示 Error

在使用计算器的时候,难免会有输入错误表达式的时候,因此在这种时候需要及时报错提醒用户,最好有具体的原因!

  • 除数分母为零的错误,需要返回错误并给出错误原因;
  • 使用科学计算e,log的时候未加括号,不能计算,会导致括号错误;
  • 输入次方等符号,需要前面先有一个数字,否则会导致语法错误

在这里插入图片描述

5. 读取历史记录History 历史记录的显示、隐藏

在需要的读取历史记录显示,在不需要的时候把历史记录给隐藏对于一个用户来说至关重要,因为我们需要一个合理简洁且能够交互的界面

6. 科学计算

科学计算通过导入math库进行计算。
在这里插入图片描述

7. Ans的处理与计算

在实际中,我们可以借助ans直接将上次的结果拿来计算
在这里插入图片描述

🏆🏆利率计算器

8. 存贷款–利息 计算

选择贷款和存款分别进行计算和交互。通过Button按钮的点击进行不同页面切换。
在这里插入图片描述

9. 存贷款–利率表 修改

用户需要自定义一些利率值,因此利率表的修改对用户也至关重要,本人采用后端数据库的所有类型和对应的值通过字典传递过来,然后借助innerHTML标签进行动态生成和动态删除。
在这里插入图片描述

10 数据库展示

在这里插入图片描述

🚌设计实现过程

1. 页面原型设计

看到页面原型设计的时候,科学计算器已经做完了,所以就用墨刀做了 另外一个利率计算器的原型设计 后期前端设计除了颜色微调了之外,其他基本全部实现

在这里插入图片描述

2. 前置知识学习

Web开发技术入门 : 根据这篇文章学了Html Css Js的一些基础操作,并进行总结整理。
Django框架的使用 :根据这篇文章学习了django的框架使用,以及django和mysql的数据操作(建立数据表,建立视图,交互方式),以及可视化mysql。
Django连接数据库,学习了在django里面用models建立类进行构建数据库里面的表,已经在views中定义函数对数据库进行增删改查。

3. 正式编码实现

前端部分代码展示

templates文件夹下保存我们所写的html标签,在static里面保存我们的CSS文件和JS文件,进行页面美化和页面交互。

  • CSS展示: 在CSS里面使用各种选择器,进行风格、样式、颜色个性化设置。
div.display #computation{
    display: block;
    font-size: 22px;
    margin: 5px auto;
    text-align: right;
    border: 1px #00539f;
}

div.display #result{
    display: block;
    font-size: 50px;
    text-align: right;
    margin: 5px auto;
    padding: 0px 0px;
}
  • HTML展示: 在这里我们写我们主要页面的代码,用于静态显示,以及对我们界面的全局架构
<div class="form_group">
  <label for="total_money1" class="form_label">金额(元):</label>
  <div class="form_input" style="display: inline-block"><input type="text" id="total_money1"></div>
  <div class="error"> </div>
</div>

<div class="form_group">
  <label for="type_id1" class="form_label">年份(年):</label>
  <div class="form_input" style="display: inline-block">
    <input type="text"  id="type_id1">
  </div>
  <div class="error"> </div>
</div>

<div class="form_group">
  <label for="secret1" class="form_label">利息(元):</label>
  <div class="form_input" style="display: inline-block">
    <input id="secret1" type="text">
  </div>
  <div class="error"></div>
</div>
  • JS展示: 在这里主要展示我们的页面交互功能
function edit() {
        let table = document.querySelector(".deposit")
        table.style.display = "block"
        if(document.getElementById("temp1").innerHTML === ""){
            $.ajax({
              url: "/indexapi_editdata",
              type: "post",
              data: {
                  name : table.className
              },
              success: function (res) {
                //alert("确定")
                console.log(res.data)
                for (const key in res.data) {
                  temp1.innerHTML += "<div><label>" + key + "</label>"
                  temp1.innerHTML += "<input type='text'  style='display: inline-block' value=" + res.data[key] + " id=" + key + "></div>"
                }
              }
            })
        }
  }

    function edit1() {
        let table = document.querySelector(".load")
        table.style.display = "block"
        if(document.getElementById("temp2").innerHTML === ""){
            $.ajax({
              url: "/indexapi_editdata1",
              type: "post",
              data: {
                  name : table.className
              },
              success: function (res) {
                //alert("确定")
                console.log(res.data)
                for (const key in res.data) {
                  temp2.innerHTML += "<div><label>" + key + "</label>"
                  temp2.innerHTML += "<input type='text' value=" + res.data[key] + " id=" + key + "></div>"
                }
              }
            })
        }
  }

前端全局代码展示:

在这里插入图片描述

后端部分代码展示

  • Views : 在里面设计数据库的处理函数,用于处理业务逻辑,产生html页面或数据。下面这两个对数据库里利率表进行更改的数据。
def indexapi_editdata(request):
    type_name = request.POST
    type_name = type_name.get("name")
    if type_name == "deposit":
        data_all = Bank1.objects.all()
    else:
        data_all = Bank3.objects.all()
    result = dict()
    for data in data_all:
        print(data.type_name,data.rate)
        result[data.type_name] = data.rate
    return JsonResponse({"code":2000,"msg":"OK","data":result})

@csrf_exempt
def indexapi_alter_rate(request):
    params1 = request.POST
    params = params1.get("rates")
    print(type(params),params)
    params = json.loads(params)
    print(type(params), params)
    for key in params.keys():
        print("key ",key,"value ",params[key])
        t = Bank1.objects.get(type_name=key)
        t.rate = float(params[key])
        t.save()
    return JsonResponse({"code":2000,"msg":"OK","data":"修改成功"})

  • models : 定义数据库里面的表,设计表的属性、类型,下面这个定义的是计算器历史记录类和 存贷款利率类
class Calculator(models.Model):
    h_history = models.CharField(max_length=100)
    h_result = models.CharField(max_length=100)
    h_date = models.DateField(default="2000-1-1")


class Bank1(models.Model):
    type_id = models.IntegerField()
    type_name = models.CharField(max_length=20)
    rate = models.FloatField()

class Bank3(models.Model):
    type_id = models.IntegerField()
    type_name = models.CharField(max_length=20)
    rate = models.FloatField()
  • urls : 在这里设置路由和views里面的函数的一一映射。 这里是一一映射关系
    url(r'^indexapi_back$', views.indexapi_back),
    url(r'^indexapi_clear$', views.indexapi_clear),
    url(r'^indexapi_ans$', views.indexapi_ans),
    url(r'^index_secret$', views.index_secret), # 初始界面函数 利率函数

后端全局代码展示:
在这里插入图片描述


💻代码说明

在这一块我重点说明一我遇到的一些问题和易混淆的方面,其他代码就不全部解释了,都在gitcode,里面也有一部分注释说明。
其次根据这次作业目前额外完成了2篇技术博客如下:
HTML 实现 点击按钮切换 整张界面 && 点击按钮切换局部界面
HTML选项框的设计 以及 根据不同选项对应不同的事件交互
后续文章还会继续整理。

1. ajax 中get和post区别

  • 最直观的区别就是GET把参数包含在URL中POST通过request body传递参数。
  • GET请求只能进行url编码,而POST支持多种编码方式
  • GET和POST还有一个重大区别,简单的说:GET产生一个TCP数据包;POST产生两个TCP数据包。 长的说:对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据);而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok(返回数据)。

2. 隐藏标签的设置

  • 我们设置页面的时候,有些部分可以不在初始界面展示,可以在点击某些特定按钮后再进行展示,因此我们可以借助按钮设置某一块的style.display=none 让其不显示,或者设置style.display=block设置为显示
  • 示例展示
function get_id(){
       let mySelect = document.getElementById("type_id");   //定位id(获取select)
       let index = mySelect.selectedIndex;   //选中索引(选取select中option选中的第几个)
       if(index === 1){
           document.getElementById("year").style.display="block"
       }
       else{
           document.getElementById("year").style.display="none"
       }
       let text = mySelect.options[index].text; //获取选中文本,即option标签对之间的文字
       let value = mySelect.options[index].value;   //获取选中值
       document.getElementById("show_id").innerHTML = value;
       if (mySelect.options[2].selected) {  //注意index是从0开始的
           document.getElementById("show_isSelected").innerHTML = "选中了";
       } else {
           document.getElementById("show_isSelected").innerHTML = "没选中";
       }
   }

3. 点击按钮实现页面切换

页面切换有以下四种方法比较合适:

方法一: 使用a标签进行跳转连接 href

 <a href="/index_secret">
     <button class="change_page">利率计算器</button>
 </a>

方法二:在button标签中加上onclick属性,赋值为Javascript

<input type="button" onclick='location.href=("index.aspx")' />//在本页面打开
<input type="button" onclick='window.open("bedzhao.aspx")' />//打开新页面

<button onclick="window.location.href='../routeEdit/index.html'" type="button" id="add">新增</button>

方法二:触发一个函数跳转

<script>
function jump(){
    window.location.href="http://blog.sina.com.cn/mleavs";
}
</script>
<input type="button" value="我是一个按钮" οnclick=javascript:jump()>

方法四:表单的action定向提交跳转

<form action="xx.html" method="post">
    <input type="button" value="按钮">
</form>

4. 判断select是否被选中并获取select选中的值

选择出来select标签中哪一个选项被选择,然后给出相应变化

var mySelect = document.getElementById("testSelect");	//定位id(获取select)
var index = mySelect.selectedIndex;	//选中索引(选取select中option选中的第几个)
var text = mySelect.options[index].text;	//获取选中文本
var value = mySelect.options[index].value;	//获取选中值
mySelect.options[index].selected	//判断select中的某个option是否选中,true为选中,false为未选中

😊心路历程和收获

  • 其实刚开看到这这个题目是有点懵的,因为前后端的框架都完全没学过,还只有五天,后来延迟了时间,时间充裕了很多,慢慢就开始学了起来,从前置知识到代码实践,一点点修改,一点点查,哪里不会查哪里,最后总算实现了一个还行的结果。
  • 自己动手编程实现了一个前后端分离的科学计算器和利率计算器,体会到 一个项目前后端结合的api设计全过程 , 包括: 开发前的计划,开发时候的需求分析,生成设计文档,实现需求的具体编码,以及开发完成后的单元测试等.
  • 在项目中发现在编写代码实现具体功能的时候,往往没有计划好的那种顺利,一般是错误频出, 比如有些语法不了解,或者不同的选择器的属性不同,前后端之间传递数据。
  • 学会了HTML+CSS+JS开发前端的一些基础和流程,包括HTML进行页面编辑,CSS对页面风格进行设计,JS进行**页面交互,**和id class name 等等选择器的使用。
  • 学会了PythonDjango框架,熟悉了其使用,也顺便复习了数据库hhhhh,会使用该库进行简单的数据库、表管理增删改查等功能。另外学会了ajax的使用,会使用POSTGET 方法进行传递通信
  • 提高了编程中debug的能力,会用debug工具进行调试python代码.
  • 学会了使用前端浏览器界面进行调整界面格式Debug, 使得界面设计更加直观动态。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1119497.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

​CUDA学习笔记(三)CUDA简介

本篇博文转载于https://www.cnblogs.com/1024incn/tag/CUDA/&#xff0c;仅用于学习。 前言 线程的组织形式对程序的性能影响是至关重要的&#xff0c;本篇博文主要以下面一种情况来介绍线程组织形式&#xff1a; 2D grid 2D block 线程索引 矩阵在memory中是row-major线性…

Cannot load from short array because “sun.awt.FontConfiguration.head“ is null

错误描述 在使用Easyexcel时发生了报错&#xff0c;请求返回空白 但是只在Linux上出现了该报错&#xff0c;在本地windows环境没有出现 JDK都使用的是17版本 错误原因 由于在linux上缺失Easyexcel使用的字体导致 解决办法 下载一个jdk1.8 在其jre/lib目录里复制fontconfi…

聊聊昨日ChatGPT全球宕机事件,带给我们的警示

作者 | 卖萌酱&#xff0c;王二狗 昨日&#xff0c;ChatGPT崩了&#xff01; 大模型研究测试传送门 GPT-4传送门&#xff08;免墙&#xff0c;可直接测试&#xff0c;遇浏览器警告点高级/继续访问即可&#xff09;&#xff1a;https://gpt4test.com 许多人发现无论是 ChatGPT…

腾讯云创建了jenkins容器,但无法访问

1、首先&#xff0c;查看本机能不能ping通你的腾讯云服务器 如果ping的通那就下一步 2、查看腾讯云服务器的防火墙关了没&#xff0c;没关关掉、 firewall-cmd --state not running 3、那就在云服务器的控制台开放端口

自然语言处理---注意力机制

注意力概念 观察事物时&#xff0c;之所以能够快速判断一种事物(当然允许判断是错误的)&#xff0c;是因为大脑能够很快把注意力放在事物最具有辨识度的部分从而作出判断&#xff0c;而并非是从头到尾的观察一遍事物后&#xff0c;才能有判断结果。正是基于这样的理论&#xf…

【数据结构】线性表(九)队列:链式队列及其基本操作(初始化、判空、入队、出队、存取队首元素)

文章目录 一、队列1. 定义2. 基本操作 二、顺序队列三、链式队列0. 链表1. 头文件2. 队列结构体3. 队列的初始化4. 判断队列是否为空5. 入队6. 出队7. 存取队首元素8. 主函数9. 代码整合 堆栈Stack 和 队列Queue是两种非常重要的数据结构&#xff0c;两者都是特殊的线性表&…

面试二总结

bean的生命周期&#xff1a; 数据库采用行级锁索引&#xff08;使用排他锁&#xff09;&#xff1a; mysql事务隔离级别 未提交读(Read uncommitted)是最低的隔离级别。通过名字我们就可以知道&#xff0c;在这种事务隔离级别下&#xff0c;一个事务可以读到另外一个事务未提交…

微信小程序自定义组件及会议管理与个人中心界面搭建

一、自定义tabs组件 1.1 创建自定义组件 新建一个components文件夹 --> tabs文件夹 --> tabs文件 创建好之后win7 以上的系统会报个错误&#xff1a;提示代码分析错误&#xff0c;已经被其他模块引用&#xff0c;只需要在 在project.config.json文件里添加两行配置 &…

gltf和glb格式模型用什么软件处理

.gltf格式本质上是一个JSON文件。它能描述一整个3D场景&#xff0c;比如一个模型使用多少个网格&#xff0c;网格的旋转、位移等信息。 .glb 文件是gltf 资源格式的二进制格式&#xff0c;一般情况它将所有依赖的资源打包在一起形成一个 xxx.glb 的资源文件&#xff0c;但是如…

Leetcode刷题解析——串联所有单词的子串

1. 题目链接&#xff1a;30. 串联所有单词的子串 2. 题目描述&#xff1a; 给定一个字符串 s 和一个字符串数组 words。 words 中所有字符串 长度相同。 s 中的 串联子串 是指一个包含 words 中所有字符串以任意顺序排列连接起来的子串。 例如&#xff0c;如果 words ["…

【软考】11.4 处理流程设计/系统设计/人机界面设计

《处理流程设计&#xff1a;物理模型》 业务流程建模 流程表示工具 N-S图&#xff08;盒图&#xff09;&#xff1a;表示嵌套和层次关系&#xff1b;不适合于复杂程序的设计问题分析图&#xff08;PAD&#xff09;&#xff1a;结构化程序设计 业务流程重组&#xff08;BPR&am…

字节码进阶之JSR269详解

字节码进阶之JSR269详解 文章目录 前言JSR269概览深入理解JSR269JSR269的应用注意事项和最佳实践总结参考文档 前言 在Java的世界中&#xff0c;我们经常会听到JSR(Java Specification Requests)的名字。JSR是Java社区的一种提案&#xff0c;它定义了Java平台的各种标准和规范…

蓝桥杯(修建灌木 C++)

思路&#xff1a;到两边的距离&#xff0c;取大的一端&#xff1b;因为会来回循环&#xff0c;所以需要乘2。 #include <iostream> using namespace std; int main() {int n;cin>>n;for(int i1;i<n;i){cout<<max(i - 1,n - i) * 2<<endl;}return 0;…

JAVA实现Jfilechooser搜索功能

JAVA实现Jfilechooser搜索功能 背景介绍需求描述思路和方法Java代码实现和注释相关知识点介绍视频演示结语 背景介绍 Java是一种面向对象的编程语言&#xff0c;广泛应用于各种应用程序开发中。文件搜索是我们在日常工作或者学习中经常会遇到的需求&#xff0c;比如查找某个文…

推特爆火!超越ChatGPT和Llama2,新一代检索增强方法Self-RAG来了原创

作者 | ZenMoore 前言 大型语言模型&#xff08;LLMs&#xff09;具有出色的能力&#xff0c;但由于完全依赖其内部的参数化知识&#xff0c;它们经常产生包含事实错误的回答&#xff0c;尤其在长尾知识中。为了解决这一问题&#xff0c;之前的研究人员提出了检索增强生成&…

062:mapboxGL通过jumpTo方式跳转到某位置

第062个 点击查看专栏目录 本示例的目的是介绍演示如何在vue+mapbox中通过jumpTo方式跳转到某位置。 直接复制下面的 vue+mapbox源代码,操作2分钟即可运行实现效果 文章目录 示例效果配置方式示例源代码(共122行)相关API参考:专栏目标示例效果 配置方式 1)查看基础设置…

基于nodejs+vue语言的酒店管理系统

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

【软考】12.2 成本管理/配置管理

《成本管理》 成本估算、成本预算、成本控制自顶向下&#xff1a;无差别的自底向上&#xff1a;有差别的应急储备&#xff1a;针对已知风险管理储备&#xff1a;针对未知风险 成本类型 可变成本&#xff08;变动成本&#xff09;&#xff1a;如材料固定成本&#xff1a;如房租…

使用Redis实现分布式锁解决商品超卖问题(接上篇文章)

1. RedLock&#xff08;红锁&#xff09;简介 RedLock是一种用于分布式系统的锁定算法&#xff0c;旨在提供分布式锁的高可用性和分布式容错性。它是由Redis的创建者Salvatore Sanfilippo提出的&#xff0c;用于克服Redis单实例的单点故障问题。RedLock的目标是确保在多个Redis…

【LeetCode】144. 二叉树的前序遍历 [ 根结点 左子树 右子树 ]

题目链接 文章目录 Python3方法一&#xff1a; 递归 ⟮ O ( n ) ⟯ \lgroup O(n) \rgroup ⟮O(n)⟯方法二&#xff1a; 迭代 ⟮ O ( n ) ⟯ \lgroup O(n) \rgroup ⟮O(n)⟯方法三&#xff1a; Morris ⟮ O ( n ) 、 O ( 1 ) ⟯ \lgroup O(n)、O(1) \rgroup ⟮O(n)、O(1)⟯ C…