用grid布局来实现一个简单新拟态计算器

2023-11-03 05:30

本文主要是介绍用grid布局来实现一个简单新拟态计算器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于vue+网格grid布局的calculator

使用的编辑器codepen 是一个浏览器在线编辑器,有兴趣的小伙伴,网上可自行了解,😉

首先看完成后的效果,也可点击这里尝试一下demo演示
在这里插入图片描述
看这篇文章的小伙伴,跟着文章弄,就可以完成一个新拟态计算器啦

文章分三步,跟我一起吧🍀

1、页面布局 HTML部分

首先我们先把主要的页面布局写好
我们需要19个按钮

    <button >AC</button><button >±</button><button >%</button><button >+</button><button >-</button><button >×</button><button >÷</button><button >=</button><button >1</button><button >2</button><button >3</button><button >4</button><button >5</button><button >6</button><button >7</button><button >8</button><button >9</button><button >0</button><button >.</button>

当然我们还需要一个结果区,用来展示输入的数字和计算后的结果

<div class="result">0
</div>

初始化为‘0’,是因为后面写逻辑代码需要

看页面
在这里插入图片描述

看基本的样式已经完成啦,接下来我们要来写css部分,再写这部分之前,我们先给html元素button便签加上style,等下使用grid布局。🌺

<div class="calculator"><div class="result" style="grid-area: result">{{ equation }}</div><button style="grid-area: ac" >AC</button><button style="grid-area: plus-minus" >±</button><button style="grid-area: percent" >%</button><button style="grid-area: add" >+</button><button style="grid-area: subtract" >-</button><button style="grid-area: multiply" >×</button><button style="grid-area: divide" >÷</button><button style="grid-area: equal">=</button><button style="grid-area: number-1" >1</button><button style="grid-area: number-2" >2</button><button style="grid-area: number-3" >3</button><button style="grid-area: number-4" >4</button><button style="grid-area: number-5" >5</button><button style="grid-area: number-6" >6</button><button style="grid-area: number-7" >7</button><button style="grid-area: number-8" >8</button><button style="grid-area: number-9" >9</button><button style="grid-area: number-0" >0</button><button style="grid-area: dot" >.</button></div>

2、页面样式 CSS部分

开始写样式了,该小demo是使用grid布局来实现的,所以让我们先来讲讲这个项目需要用到的grid布局属性🍃

目前css布局方案中,网格布局可以算得上是最强大的布局方案了。它可以将网页分为一个个网格,然后利用这些网格组合做出各种各样的布局。
基本概念

1.容器和项目🍆
采用网格布局的区域,称为“容器”。容器内部的采用网格定位的子元素称为“项目”

2 容器属性🥒
display属性

display:grid指定一个容器为网格布局

3 grid-template-columns和 grid-template-rows🥕

grid-template-columns:用来指定行的宽度
grid-template-rows:用来指定行的高度
.wrapper{width:450px;background: #e5e5e5;text-align:center;display: inline-grid;grid-template-columns: 150px 150px 150px;grid-template-rows: 150px 150px 150px}

上面这段代码指定的宽高各为150px

当然,出来能指定具体的数值之外,也可以使用百分比来表示

.wrapper {display: grid;grid-template-columns: 33.33% 33.33% 33.33%;grid-template-rows: 33.33% 33.33% 33.33%;
}

3.1 repeat
有时候,重复写同样的值非常麻烦,尤其网格很多时。这时,可以使用repeat()函数,简化重复的值。上面的代码用repeat()改写如下

.wrapper {display: grid;grid-template-columns: repeat(3, 33.33%);grid-template-rows: repeat(3, 33.33%);
}

repeat接受两个参数:第一个数重复的次数(上面的例子是重复3次),第二个是重复的值(上面例子是33.33%)

grid属性不只这些,但我们暂时需要的就是以上的,想要了解更多的,可以看看这篇文章 手把手教你grid布局🙎‍♂

好了,让我们开始写计算器的样式
1、计算器整体样式

.calculator {//设置小格子的宽高--button-width: 80px;--button-height: 80px;//设置网格布局display: grid;//设置网格具体的放置,和之前html设置的style="grid-area: "有关grid-template-areas: "result result result result""ac plus-minus percent divide""number-7 number-8 number-9 multiply""number-4 number-5 number-6 subtract""number-1 number-2 number-3 add""number-0 number-0 dot equal";//看文章3.1,有解释哦grid-template-columns: repeat(4, var(--button-width));grid-template-rows: repeat(6, var(--button-height));//实现拟态效果 box-shadow: -8px -8px 16px -10px rgba(255, 255, 255, 1), 8px 8px 16px -10px rgba(0, 0, 0, .15);padding: 24px;border-radius: 20px;
}

2、按钮样式

.calculator button {margin: 8px;padding: 0;border: 0;display: block;outline: none;border-radius: calc(var(--button-height) / 2);font-size: 24px;font-family: Helvetica;font-weight: normal;color: #999;background: linear-gradient(135deg, rgba(230, 230, 230, 1) 0%, rgba(246, 246, 246, 1) 100%);//拟态实现box-shadow: -4px -4px 10px -8px rgba(255, 255, 255, 1), 4px 4px 10px -8px rgba(0, 0, 0, .3);
}

3、点击后的按钮效果

这里只是加了inset

.calculator button:active {box-shadow: -4px -4px 10px -8px rgba(255, 255, 255, 1) inset, 4px 4px 10px -8px rgba(0, 0, 0, .3) inset;
}

4、最后是结果区

.result {text-align: right;line-height: var(--button-height);font-size: 48px;font-family: Helvetica;padding: 0 20px;color: #666;
}

3、逻辑书写 JS部分

首先我们需要设置一下vue的环境
在这里插入图片描述
点击setting
在这里插入图片描述
在搜索框里查找vue,选择保存就可以
之后我们在html文件body里面的元素外层包裹

<div id="app">代码。。
</div>

同时,我们先为html的button元素加上 @click事件

<button style="grid-area: ac" @click="clear">AC</button>
<button style="grid-area: plus-minus" @click="calculateToggle">±</button>
<button style="grid-area: percent" @click="calculatePercentage">%</button>
<button style="grid-area: add" @click="append('+')">+</button>
<button style="grid-area: subtract" @click="append('-')">-</button>
<button style="grid-area: multiply" @click="append('×')">×</button>
<button style="grid-area: divide" @click="append('÷')">÷</button>
<button style="grid-area: equal" @click="calculate">=</button><button style="grid-area: number-1" @click="append(1)">1</button>
<button style="grid-area: number-2" @click="append(2)">2</button>
<button style="grid-area: number-3" @click="append(3)">3</button>
<button style="grid-area: number-4" @click="append(4)">4</button>
<button style="grid-area: number-5" @click="append(5)">5</button>
<button style="grid-area: number-6" @click="append(6)">6</button>
<button style="grid-area: number-7" @click="append(7)">7</button>
<button style="grid-area: number-8" @click="append(8)">8</button>
<button style="grid-area: number-9" @click="append(9)">9</button>
<button style="grid-area: number-0" @click="append(0)">0</button><button style="grid-area: dot" @click="append('.')">.</button>

绑定的几个函数
isOperator()
append()
calculate()
calculateToggle()
calculatePercentage()
clear()

new Vue({el: '#app',data: {equation: '0',isDecimalAdded: false,isOperatorAdded: false,isStarted: false,},methods: {// Check if the character is + / - / × / ÷isOperator(character) {return ['+', '-', '×', '÷'].indexOf(character) > -1},// When pressed Operators or Numbersappend(character) {// Startif (this.equation === '0' && !this.isOperator(character)) {if (character === '.') {this.equation += '' + characterthis.isDecimalAdded = true} else {this.equation = '' + character}this.isStarted = truereturn}// If Numberif (!this.isOperator(character)) {if (character === '.' && this.isDecimalAdded) {return}if (character === '.') {this.isDecimalAdded = truethis.isOperatorAdded = true} else {this.isOperatorAdded = false}this.equation += '' + character}// Added Operatorif (this.isOperator(character) && !this.isOperatorAdded) {this.equation += '' + characterthis.isDecimalAdded = falsethis.isOperatorAdded = true}},// When pressed '='calculate() {let result = this.equation.replace(new RegExp('×', 'g'), '*').replace(new RegExp('÷', 'g'), '/')this.equation = parseFloat(eval(result).toFixed(9)).toString()this.isDecimalAdded = falsethis.isOperatorAdded = false},// When pressed '+/-'calculateToggle() {if (this.isOperatorAdded || !this.isStarted) {return}this.equation = this.equation + '* -1'this.calculate()},// When pressed '%'calculatePercentage() {if (this.isOperatorAdded || !this.isStarted) {return}this.equation = this.equation + '* 0.01'this.calculate()},// When pressed 'AC'clear() {this.equation = '0'this.isDecimalAdded = falsethis.isOperatorAdded = falsethis.isStarted = false}}
})

运行就可以实现啦
快来动手试试吧😺

这篇关于用grid布局来实现一个简单新拟态计算器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/335912

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal