vue.js+element-ui的基础表单

遇到原生的html小型单页应用时,是脱离了vue框架,而我们又想使用vue的语法和element的组件加快我们的开发速度,这个时候就需要引用他们的js了。技术栈即html+vue.js+element-ui。而使用它们的方法也很简单,引入对应的js和css文件即可。下面用一个小例子展示下。

 普普通通的表单页面:

 html代码:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>表单页面</title><!-- 引入样式 --> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/element-ui/lib/theme-chalk/index.css"><!-- 引入组件库 --><script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script><script src="https://cdn.jsdelivr.net/npm/element-ui/lib/index.js"></script>  
</head>
<style>#app {display: flex;justify-content: center;align-items: center;padding: 0 20px;margin-top: 10vh;}html{width: 100%;height: 100%;background: #f0faff;}.el-form {max-width: 600px;width: 100%;box-shadow: 1px 1px 8px #dedede;padding: 30px;border-radius: 10px;background: #fff;}.el-row {margin-bottom: 20px;}/* .el-button {width: 100%;} */
</style>
<body><div id="app"><el-form ref="form" :model="formData" :rules="formRules" label-width="80px"><el-row><h3>业务数据导入终端:</h3></el-row><el-row><el-form-item label="邮箱" prop="email"><el-input placeholder="请输入接收通知的邮箱" v-model="formData.email"></el-input></el-form-item></el-row><el-row><el-col :span="12"><el-form-item label="IP地址" prop="ip"><el-input v-model="formData.ip"></el-input></el-form-item></el-col><el-col :span="12"><el-form-item label="端口" prop="port"><el-input v-model="formData.port"></el-input></el-form-item></el-col></el-row><el-row><el-col :span="12"><el-form-item label="账号" prop="username"><el-input v-model="formData.username"></el-input></el-form-item></el-col><el-col :span="12"><el-form-item label="密码" prop="password"><el-input v-model="formData.password" type="password"></el-input></el-form-item></el-col></el-row><el-row><el-col :span="12"><el-form-item label="数据库" prop="database"><el-input v-model="formData.database"></el-input></el-form-item></el-col><el-col :span="12"><el-form-item label="表名" prop="table"><el-input v-model="formData.table"></el-input></el-form-item></el-col></el-row><el-row><el-col :span="24"><el-form-item label="上传文件"><el-uploadclass="upload-demo"ref="upload":action="uploadUrl":before-upload="beforeUpload"accept=".xlsx,.xls":limit="1":auto-upload="false"><el-button slot="trigger" size="small" type="primary">选取文件</el-button><div slot="tip" class="el-upload__tip">只能上传excel文件</div></el-upload></el-form-item></el-col></el-row><el-row><el-col :span="24" style="text-align: center; margin-top: 20px;"><el-button type="primary" @click="submitForm" :disabled="disabled">{{buttonText }}</el-button><el-button type="danger" @click="clear">清除缓存</el-button></el-col></el-row></el-form></div><script>new Vue({el: '#app',data() {return {timer:0,limitTime: 1 * 60, // 限制时间为10分钟disabled:false,formRules:{email:[{ required: true, message: '请输入联系邮箱', trigger: 'blur' }],ip: [{ required: true, message: '请输入ip', trigger: 'blur' }],port: [{ required: true, message: '请输入端口', trigger: 'blur' }],username: [{ required: true, message: '请输入账号', trigger: 'blur' }],password: [{ required: true, message: '请输入密码', trigger: 'blur' }],database: [{ required: true, message: '请输入数据库', trigger: 'blur' }],table: [{ required: true, message: '请输入表名', trigger: 'blur' }],},formData: {email:'',ip: '',port: '',username: '',password: '',database: '',table: '',},uploadUrl: '/upload'  // 文件上传的接口地址};},mounted(){var obj = localStorage.getItem("formData")||"";var timer = localStorage.getItem("disabled")||"";if(timer){  //定时还没结束,重置this.disabled = true;this.timer = this.limitTime;const countdown = setInterval(() => {this.timer--;if (this.timer <= 0) {localStorage.removeItem("disabled");clearInterval(countdown);this.disabled = false;}}, 1000);}if(obj){this.formData = JSON.parse(obj);}},computed: {buttonText() {if (this.disabled) {const minutes = Math.floor(this.timer / 60);const seconds = this.timer % 60;return `禁用中 (${minutes}:${String(seconds).padStart(2, '0')})`;} else {return '提交';}},},methods: {beforeUpload(file) {// 上传文件之前的钩子函数,可用于校验文件类型等const isExcel = ((file.type === 'application/vnd.ms-excel')||(file.type === 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'));return isExcel;},clear(){this.$confirm('该操作会清除本地保存的数据信息, 是否继续?', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {localStorage.clear();this.$message({type: 'success',message: '清除成功'});setTimeout(()=>{window.location.reload();},1000)}).catch(() => {this.$message({type: 'info',message: '已取消删除'});          });},submitForm() {this.$refs.form.validate(valid => {if (valid) {// 提交表单的函数,将表单数据和文件一起发送给后端const formData = new FormData();formData.append('email', this.formData.email);formData.append('ip', this.formData.ip);formData.append('port', this.formData.port);formData.append('access', this.formData.username);formData.append('password', this.formData.password);formData.append('dataName', this.formData.database);formData.append('tableName', this.formData.table);console.log(this.$refs.upload.uploadFiles[0]);if(this.$refs.upload.uploadFiles[0]&&this.beforeUpload(this.$refs.upload.uploadFiles[0].raw)){const file = this.$refs.upload.uploadFiles[0].raw;formData.append('file', file);}else{this.$message.error('请上传excel文件');return;}localStorage.setItem("formData",JSON.stringify(this.formData));this.disabled = true;localStorage.setItem("disabled",this.disabled)this.timer = this.limitTime;const countdown = setInterval(() => {this.timer--;if (this.timer <= 0) {localStorage.removeItem("disabled");clearInterval(countdown);this.disabled = false;}}, 1000);// 发送表单数据和文件给后端fetch('http://localhost/from/uploadExcel', {method: 'POST',body: formData}).then(response => response.json()).then(data => {console.log('提交成功', data);if(data.code==200){this.$message({message: data.msg,type: 'success'});}else{this.$message({message: data.msg,type: 'warning'});}// 处理后端返回的数据}).catch(error => {console.error('提交失败', error);// 处理提交失败的情况});} else {this.$message.error('请将表单补充完整');}});}}});</script>
</body></html>

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL定时任务Event详解

文章目录 基本概念一、Event事件使用权限二、开启\关闭Event事件三、Event事件定义格式四、事件调度使用案例4.1 准备工作4.2 创建单次定时执行事件4.2.1 创建指定时间单次执行事件任务4.2.2 创建延迟时间单次执行事件任务4.2.3 创建单次执行事件任务[多SQ执行] 4.3 创建循环定…

数据仓库的数据处理架构Lambda和Kappa

1.数据仓库 数据仓库(Data Warehouse),简写DW。顾名思义,数据仓库是一个很大的数据存储集合,为企业分析性报告和决策支持而创建,是对多元业务数据的筛选与整合,具备一定的BI能力,主要用于企业的数据分析、数据挖掘、数据报表等方向,指导业务流程改进、监视时间、成本、…

从0到1实现RPC | 03 重载方法和参数类型转换

一、存在的问题 1.重载方法在当前的实现中还不支持&#xff0c;调用了会报错。 2.类型转换也还存在问题。 假设定义的接口如下&#xff0c;参数是float类型。 在Provider端接受到的是一个Double类型&#xff0c;这是因为web应用接收的请求后处理的类型。 在反射调用的时候就会…

前言:为什么C语言最适合编程入门?

前言&#xff1a;为什么C语言最适合编程入门&#xff1f; C语言被认为最适合编程入门的原因主要有以下几点&#xff1a; 基础且强大&#xff1a;C语言是一种基础且强大的编程语言。它提供了对底层硬件的直接访问&#xff0c;让初学者能够更好地理解计算机的工作原理&#xff0…

从零开始学Spring Boot系列-集成Kafka

Kafka简介 Apache Kafka是一个开源的分布式流处理平台&#xff0c;由LinkedIn公司开发和维护&#xff0c;后来捐赠给了Apache软件基金会。Kafka主要用于构建实时数据管道和流应用。它类似于一个分布式、高吞吐量的发布-订阅消息系统&#xff0c;可以处理消费者网站的所有动作流…

基于python+vue的O2O生鲜食品订购flask-django-nodejs-php

近年来互联网络的迅猛发展和电子终端设备的普及&#xff0c;赋予了各行业充足的发展空间。微信小程序的O2O生鲜食品订购相比于传统信息技术&#xff0c;时效性是它最大的特色&#xff0c;已经在电子娱乐、经济等中发挥着举足轻重的作用。短时间内迅速扩大了线上管理系统的规模。…

了解云原生

1、云原生学习路线 学习云原生(Cloud Native)技术涉及了解和掌握一系列的概念、技术和工具。云原生是一种构建和运行应用程序的方法&#xff0c;旨在充分利用云计算的灵活性、可伸缩性和弹性。以下是一个可以参考的学习路线&#xff1a; 了解云原生基础 学习云计算的基本概念&…

此站点正在尝试打开 ,chrome/edge 允许http网站打开url schema

正常https链接会有首次允许选项 但http没有&#xff0c;每次都会弹出&#xff0c;非常烦人。 Chrome / Edge 配置 地址栏输入 chrome://flags/搜索Insecure origins treated as secure, 配置允许网站&#xff0c;需要协议和端口再次跳转会显示始终允许选项

puppeteer使用示例云顶之弈官网

自己从0到1开发的&#xff0c;微信小程序【云顶宝藏】求求点个5星好评吧&#xff01; 需求&#xff1a;拿到所有英雄的信息 思路&#xff1a;点击每个英雄&#xff0c;进入英雄详情页&#xff0c;拿信息&#xff0c;并返回&#xff0c;继续下一个英雄** 最终效果 本地环境 win…

docker进阶篇,docker集群介绍

docker swarm 官网&#xff1a;https://docs.docker.com/engine/swarm/how-swarm-mode-works/nodes/ 什么是 docker swarm docker swarm 是 docker 官方提供的容器编排和集群管理工具。它允许用户将多个 docker 主机组成一个虚拟的 docker 集群&#xff0c;以便更高效地管理…

云计算系统等保测评对象和指标选取

1、云计算服务模式与控制范围关系 参考GBT22239-2019《基本要求》附录D 云计算应用场景说明。简要理解下图&#xff0c;主要是云计算系统安全保护责任分担原则和云服务模式适用性原则&#xff0c;指导后续的测评对象和指标选取。 2、测评对象选择 测评对象 IaaS模式 PaaS模式…

文本处理(有关go web方面)

文本处理 3.21 本文基本摘录至https://learnku.com/docs/build-web-application-with-golang/073-regular-processing/3197&#xff0c;仅供学习&#xff0c;如果有需要学习web的同学可以看这个&#xff0c;不懂的再来看我的&#xff0c;我的仅作补充 文本处理是什么&#xf…

基于CSS3制作专属可自由旋转的立方体

一、代码区域 1.1 css3代码区域 <style>* {padding: 0;margin: 0;list-style: none;}/* 1) 定义动画 */keyframes loop {0% {transform: rotateX(348deg) rotateY(67deg) rotateZ(95deg);}50% {transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg);}100% {transform:…

论文阅读-MIPD:一种用于分布式深度神经网络训练的自适应梯度稀疏化框架

摘要—基于参数服务器架构的异步训练广泛应用于大规模数据集和深度神经网络模型的扩展训练。在大规模分布式深度学习系统中&#xff0c;通信一直被认为是主要瓶颈。最近的研究尝试通过梯度稀疏化和量化方法来减少通信流量。我们发现前期研究存在三个限制。首先&#xff0c;他们…

基于python+vue网络相册设计与实现flask-django-nodejs-php

网络相册设计与实现的目的是让使用者可以更方便的将人、设备和场景更立体的连接在一起。能让用户以更科幻的方式使用产品&#xff0c;体验高科技时代带给人们的方便&#xff0c;同时也能让用户体会到与以往常规产品不同的体验风格。 与安卓&#xff0c;iOS相比较起来&#xff0…

蓝桥杯2021年第十三届省赛真题-卡片

一、题目 卡片 小蓝有很多数字卡片&#xff0c;每张卡片上都是数字 0 到 9。 小蓝准备用这些卡片来拼一些数&#xff0c;他想从 1 开始拼出正整数&#xff0c;每拼一个&#xff0c; 就保存起来&#xff0c;卡片就不能用来拼其它数了。 小蓝想知道自己能从 1 拼到多少。 例如&am…

Cookie和Session登录注册案例

文章目录 一、需求说明![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/f29467ed6b7f4de7a568004ad50de591.png)二、用户登录1、Dao层代码2、Service层代码3、Web层代码 三、记住用户四、用户注册五、展示验证码 一、需求说明 二、用户登录 1、Dao层代码 UserMapp…

双指针(滑动窗口)-算法刷题

一.移动零 算法思想 &#xff1a; 设置两个指针left,right&#xff0c;将数组分为三块[0,left]为不为0的元素&#xff0c;[left1,right-1]为0元素&#xff0c;[right,num.size()-1]为未扫描的区域&#xff0c;判断right位置&#xff0c;不为0元素则与left1位置元素交换,left和r…

使用jupyter-Python进行模拟股票分析

tushare财经数据接口包 pip install tushare作用&#xff1a;提供相关指定的财经数据 需求&#xff1a;股票分析 使用tushare包获取某股票的历史行情数据 输出该股票所有收盘比开盘上涨3%以上的日期 输出该股票所有开盘比前日收盘跌幅超过2%的日期 假如我从2015年1月1日开…

人像抠图HumanSeg——基于大规模电话会议视频数据集的连接感知人像分割

前言 人像抠图将图像中的人物与背景进行像素级别的区分的技术。通过人像分割&#xff0c;可以实现诸如背景虚化、弹幕穿人等各种有趣的功能&#xff0c;为视频通话和影音观看提供更加优质和丰富的体验。由于广泛部署到Web、手机和边缘设备&#xff0c;肖像分割在兼顾分割精度的…