前端(二)VUE功能集锦

一、引言

        作者开发工具平台的时候,用到了vue和element-ui,这里写一下各种功能使用,有的是绕点弯路,有的是需要结合实现需要自己改写一下。

二、功能

        先看看环境,作者后端是SpringBoot,前端是VUE+ElementUI,前端文件直接放在esources的static里面,没有做前后端分离,毕竟这个平台是属于我们部门的,没有专门的前端人员

1、悬浮显示

        有些内容比较长,需要只展示一部分,还要把鼠标悬浮的时候,展示全部内容r

html:
<el-tooltip :content="code" placement="top"><div class="ellipsis">{{ code }}</div></el-tooltip>css:.ellipsis {white-space: nowrap;overflow: hidden;text-overflow: ellipsis;}

2、点击图标复制

html:
<el-button type="text" icon="el-icon-document-copy"
@click="copyContent(code)"></el-button>js:
copyContent(content) {const el = document.createElement('textarea');el.value = content;document.body.appendChild(el);el.select();document.execCommand('copy');document.body.removeChild(el);_this.$message.success('内容已复制');},

3、数据转换展示

        有时候需要把数据转换一遍再展示,比如日期

html:
<template slot-scope="scope">{{ formatDate(scope.row.createTime) }}</template>js:
formatDate(timestamp) {const date = new Date(timestamp);return date.toLocaleDateString();},

4、文本输入框高度

        试了style样式的高度设置,还有!important之类的强设置,没用

        内容输入框只能使用 :rows进行设置高度或者重写组件,如果要重写就太麻烦了

<el-input placeholder="请输入" type="textarea" :rows="25"style="width: 100%;height:600px !important"size="medium"clearablev-model="createForm.content"></el-input>

5、输入或者选择事件

        在用户输入或者选择一些内容的时候,需要识别到内容是什么,有时候要特殊处理,比如数据库相关展示db、表,日志相关展示标题、信息等等

选择

html:
<el-select filterable placeholder="请选择" :disabled="detailFlag || detailStepFlag"v-model="createStepForm.stepType"@change="handleStepTypeChange"><el-option :key="step.code" :label="step.name" :value="step.code"v-for="step in stepTypeList"></el-option></el-select>js:handleStepTypeChange(value) {if (_this.createStepForm.stepType === 'log') {//业务处理}
},

输入框 

html:
<el-input placeholder="请输入" style="width: 200px;" size="mini" clearable@change="handleSecretChange":disabled="detailFlag || detailStepFlag"v-model="createStepForm.secretKey"></el-input>js:
handleSecretChange() {//业务处理},

6、根据输入值加载远程数据

html:
<el-selectv-model="createForm.e"multiplefilterableremote:remote-method="searchEe":loading="loadingE":options="es"placeholder="请选择"style="width: 200px;"><el-option v-for="item in es" :key="item.e" :label="item.eDesc":value="item.e"></el-option></el-select>js:
searchEmail(queryString) {_this.loadingEmail = true;// 模拟异步加载数据setTimeout(() => {let url = '/eQuery/eInfo?value=' + queryString;_this.axios.post(url).then(function (response) {if (response.data && response.data.data) {_this.es = response.data.data.map(x => {let res = {};res.e = x.e;res.eDesc = xdisName;return res;})_this.loadingEmail = false;}});}, 1000);},

7、表格内容互换 

        比如需要选择一些任务,点击到另外一个表格里面,把需要真正执行的任务发给后端

<el-table :data="sourceList"@row-click="handleClickChange":row-class-name="tableRowClassName":highlight-current-row="false":header-cell-style="{color: '#fff',background: '#0a3370',fontWeight: '700',}":header-fixed="true"@selection-change="moveSelectedData" style="height:300px;width: 100%;overflow: auto"><el-table-column type="selection" width="55"></el-table-column><el-table-columnlabel="序号"type="index"width="80"></el-table-column></el-table><el-row style='font-weight: bold;font-size: 18px;margin-bottom: 25px'>执行一览</el-row><el-table :data="executeList"@row-click="handleClickChange":row-class-name="tableRowClassName":highlight-current-row="false":header-cell-style="{color: '#fff',background: '#0a3370',fontWeight: '700',}":header-fixed="true"style="height:300px;width: 100%;overflow: auto"><el-table-columnlabel="序号"type="index"width="80"></el-table-column><el-table-columnlabel="操作"prop="operate"><template slot-scope="scope"><el-button type="danger" size="mini" @click="removeFromRight(scope.row)">删除</el-button></template></el-table-column></el-table>

        移动到任务表格

moveSelectedData(selectedData) {console.log("moveSelectedData selectedData:" + JSON.stringify(selectedData));_this.executeList = _this.executeList.concat(selectedData);console.log("moveSelectedData executeList:" + JSON.stringify(_this.executeList));
//把原始表格这条数据删除_this.sourceList = _this.sourceList.filter(item => !selectedData.includes(item));},

        如果是点错了,需要能够把任务表格的数据删除,这里的删除也不是真的删除,是把数据放回原始表格

removeFromRight(row) {const index = _this.executeList.findIndex(data => data.code === row.code);if (index !== -1) {_this.executeList.splice(index, 1);_this.sourceList.push(row);}},

8、表格样式 

        表格如果光秃秃的直接用组件,也不好看,所以需要修改一下样式,上面作者的表格也能看的html里面的一些样式

css

.el-table,.el-table__expanded-cell {background-color: transparent;color: #93dcfe;font-size: 20px;}.el-table th,.el-table tr,.el-table td {background-color: transparent;border: 0px;color: #93dcfe;font-size: 16px;height: 5px;font-family: Source Han Sans CN Normal, Source Han Sans CN Normal-Normal;font-weight: Normal;}.el-table::before {height: 0px;}.el-table__body tr,.el-table__body td {padding: 0;height: 12px;}.el-table tbody tr:hover > td {background: #063570 !important;}.el-table__header-wrapper {border: solid 1px #04c2ed;}.el-table__row.warning-row {background: #063570;}.el-table__body-wrapper::-webkit-scrollbar-track {background-color: #063570;}.el-table__body-wrapper::-webkit-scrollbar {width: 10px;opacity: 0.5;}.el-table__body-wrapper::-webkit-scrollbar-thumb {border-radius: 12px;background-color: #0257aa;}

        看看效果呢 ,鼠标放上去还会变色的

三、总结

        前端就是做画面的,应该什么逻辑都不要有,而不是看一些逻辑前后端谁做会省力,不过看我们这边的前端部门,做的大了之后还是不可避免的会有一些逻辑,只能说尽量保持纯净吧。

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

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

相关文章

水质净化厂物联网远程监控系统解决方案

水质净化厂物联网远程监控系统解决方案 随着科技的不断发展&#xff0c;物联网技术逐渐走进我们的生活。在水质净化厂中&#xff0c;物联网技术可以应用于远程监控系统&#xff0c;实现对水质净化过程的实时监测和数据分析&#xff0c;从而提高净化效率和管理水平。 一、需求分…

操作系统课程设计-内存管理

目录 前言 1 实验题目 2 实验目的 3 实验内容 3.1 步骤 3.2 关键代码 3.2.1 显示虚拟内存的基本信息 3.2.2 遍历当前进程的虚拟内存 4 实验结果与分析 5 代码 前言 本实验为课设内容&#xff0c;博客内容为部分报告内容&#xff0c;仅为大家提供参考&#xff0c;请勿直…

首届PolarDB开发者大会在京举办,阿里云李飞飞:云数据库加速迈向智能化

1月17日&#xff0c;阿里云PolarDB开发者大会在京举办&#xff0c;中国首款自研云原生数据库PolarDB发布“三层分离”新版本&#xff0c;基于智能决策实现查询性能10倍提升、节省50%成本。此外&#xff0c;阿里云全新推出数据库场景体验馆、训练营等系列新举措&#xff0c;广大…

QT第六天

要求&#xff1a;使用QT绘图&#xff0c;完成仪表盘绘制&#xff0c;如下图。 素材 运行效果&#xff1a; 代码&#xff1a; widget.h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QPainter> #include <QPen>QT_BEGIN_NAMESPACE name…

S/MIME电子邮件证书申请指南

近年来&#xff0c;邮件安全问题日益突出&#xff0c;电子邮件成为诈骗、勒索软件攻击的重灾区。恶意邮件的占比屡创新高&#xff0c;邮件泄密事件更是比比皆是。在如此严峻的网络安全形势下&#xff0c;使用S/MIME电子邮件证书进行邮件收发是当今最佳的邮件安全解决方案之一。…

Apache Doris (六十四): Flink Doris Connector - (1)-源码编译

🏡 个人主页:IT贫道-CSDN博客 🚩 私聊博主:私聊博主加WX好友,获取更多资料哦~ 🔔 博主个人B栈地址:豹哥教你学编程的个人空间-豹哥教你学编程个人主页-哔哩哔哩视频 目录 1. Flink与Doris版本兼容

结构体内存对齐的跨平台做法

作者&#xff1a;朱金灿 来源&#xff1a;clever101的专栏 为什么大多数人学不会人工智能编程&#xff1f;>>> 之前写了一篇文章&#xff1a;使用标准C库读文件时需要注意的一个问题&#xff0c;今天发现是错误的。正确的做法是使用#pragma pack预处理指令。示例程序…

无需信用卡注册美区Apple ID指南

第一步 准备工作 1、一个没有注册过AppleID的邮箱&#xff0c;建议最好是Gmail邮箱 2、一个苹果手机&#xff0c;当然这个是必须的 3、需要科学上网 第二步 苹果网站注册 为了避免cookie的干扰&#xff0c;最好是在无痕模式下打开以上网页&#xff0c;创建你的AppleID&#…

【云原生】springboot 整合 OpenTelemetry

目录 一、前言 二、应用可观测性概述 2.1 什么是可观测性 2.2 可观测性三大指标 2.2.1 指标&#xff08;Metrics&#xff09; 2.2.2 日志&#xff08;log&#xff09; 2.2.3 追踪(Traces) 三、OpenTelemetry 介绍 3.1 什么是OpenTelemetry 3.2 OpenTelemetry架构和组件…

LiveGBS流媒体平台GB/T28181功能-基础配置接入控制白名单黑名单配置控制设备安全接入设备单独配置接入密码

LiveGBS基础配置接入控制白名单黑名单配置控制设备安全接入设备单独配置接入密码 1、白名单配置应用场景2、接入控制2.1、白名单2.2、黑名单 3、搭建GB28181视频直播平台 1、白名单配置应用场景 LiveGBS国标流媒体服务&#xff0c;支持白名单配置。 可在设备注册前&#xff0…

最新版git2.43安装、记住用户名和密码以及tortoisegit2.15使用

一、下载git 打开git官网地址&#xff1a;https://git-scm.com/进行下载 下载完安装&#xff0c;一直next就好&#xff0c;如果愿意就可以改下安装路径&#xff0c;改在d盘。 具体可以参考&#xff1a;git安装教程 二、安装完下载小乌龟以及中文语言包 下载地址&#xff1a;…

小程序中使用上传图片,显示、删除、预览

一、功能介绍 需要哦用户点击加号上传图片&#xff0c;并展示所上传图片和能够删除和预览 二、功能实现 采用的uniapp&#xff0c;创建了一个view容器包裹加号图标和展示的图片。 内部展示图片超过9张时候&#xff0c;加号图片隐藏 <view class"img-list">/…

12AOP面向切面编程/GoF之代理模式

先看一个例子&#xff1a; 声明一个接口&#xff1a; // - * / 运算的标准接口! public interface Calculator {int add(int i, int j);int sub(int i, int j);int mul(int i, int j);int div(int i, int j); }实现该接口&#xff1a; package com.sunsplanter.prox…

私有仓库工具Nexus Maven如何部署并实现远程访问管理界面

文章目录 1. Docker安装Nexus2. 本地访问Nexus3. Linux安装Cpolar4. 配置Nexus界面公网地址5. 远程访问 Nexus界面6. 固定Nexus公网地址7. 固定地址访问Nexus Nexus是一个仓库管理工具&#xff0c;用于管理和组织软件构建过程中的依赖项和构件。它与Maven密切相关&#xff0c;可…

谈谈前端开发中的防抖和节流

本文作者为 360 奇舞团前端开发工程师 李武阳 概述 防抖和节流是前端开发中常用的函数优化手段&#xff0c;它们可以限制函数的执行频率&#xff0c;提升性能和用户体验。主要用于处理高频触发的事件&#xff0c;例如&#xff1a;用户的滚动、输入、点击和表单的重复提交等。 防…

数据结构之list类

前言 list是列表类。从list 类开始&#xff0c;我们就要接触独属于 Python 的数据类型了。Python 简单、易用&#xff0c;很大一部分原因就是它对基础数据类型的设计各具特色又相辅相成。 话不多说&#xff0c;让我们开始学习第一个 Python 数据类型一list。 1. list的赋值 输…

[Android] Android架构体系(1)

文章目录 Android 的框架Dalvik 虚拟机JNI原生二进制可执行文件Android NDK中的binutils Bionic谷歌考虑到的版权问题Bionic与传统的C标准库&#xff08;如glibc&#xff09;的一些不同 参考 Android 的框架 Android 取得成功的关键因素之一就是它丰富的框架集。 没有这些框架…

【问题解决】cannot import name ‘circle‘ from ‘skimage.draw‘ 问题解决

使用 from skimage.draw import circle 报错如下&#xff1a; from skimage.draw import circle ImportError: cannot import name circle from skimage.draw (/home/onur/.local/lib/python3.9/site-packages/skimage/draw/__init__.py)修改&#xff1a; from skimage.draw …

Linux_Docker图形化工具Portainer如何安装并结合内网穿透实现远程访问

文章目录 前言1. 部署Portainer2. 本地访问Portainer3. Linux 安装cpolar4. 配置Portainer 公网访问地址5. 公网远程访问Portainer6. 固定Portainer公网地址 前言 本文主要介绍如何本地安装Portainer并结合内网穿透工具实现任意浏览器远程访问管理界面。Portainer 是一个轻量级…