【前端系列】- 日常笔记

简介: 记录我从自学做毕业设计到工作时候所遇到的不懂点,使用vue2+elemenent-ui过程中的一些独特的记录。

简介

记录我从自学做毕业设计到工作时候所遇到的不懂点,使用vue2+elemenent-ui过程中的一些独特的记录。因为我主要是面向后端,从毕业前自己制作毕业设计到工作,对于vue都是直接上手学习,不懂百度的那种,个人觉得这样效果还是不错,各位读者如果是初步踏入,可以将自己的不懂点逐一记录。

el-card样式修改

在element-ui中,el-card会自带padding属性,如果不是很喜欢,或者需要自定义,可以使用:body-style进行修改。一下提供一个例子进行将padding设置为0

<el-card:body-style="{padding:'0'}"style="  min-height: 80vh;">  ....
</el-card>

鼠标划过颜色变化

这个效果是当需要指针指向的时候会有颜色的变化,实际上就是一个默认的鼠标事件onmouseover/onmouseout,样例如下:

<buttonclass="z-button"onmouseover="this.style.color='#409EFF'"onmouseout="this.style.color='#000000'"@click="addMajor">    添加专业
</button>

不同屏幕大小,比例缩放

这个应该是叫响应式缩放,通过浏览器的缩放,将整体进行缩放。一般会导致缩放不规则,导致在不同的分辨率显示器上会有不同的效果,这个做法可能有很多个,但是,我这里就做一种我之前做毕设前台界面的做法。

将长度定死,然后设置margin: 0 auto ,因为我不是专门前端的,可能真正的决策方案并不是我这样的,毕竟当时我也是在做尝试。

<el-rowstyle="margin: 0 auto; width: 1280px;":gutter="20">//.....
</el-row>

效果会跟如下一致:

vue组件的富文本

对于富文本有许多种,这里使用vue组件的富文本

安装mavon-editor

cnpm install mavon-editor --save

注册

需要在main.js中去进行全局注册

// 全局注册
import Vue from 'vue'
import mavonEditor from 'mavon-editor'
import 'mavon-editor/dist/css/index.css'
// use
Vue.use(mavonEditor)

解析md文档

安装两个组件就可以

# 用于解析md文档
cnpm install markdown-it --save
# md样式
cnpm install github-markdown-css

el-table 表头居中

关于el-table表头居中,可以直接使用:header-cell-style="{'text-align':'center'}"进行居中

<el-table:header-cell-style="{'text-align':'center'}"size="small":data="tableData"borderstyle="width: 100%">       // ....
</el-table>

如果是在行中设置居中就会全部都居中

<el-table-columntype="index"align="center"//居中label="序号"width="60px"></el-table-column>

渐变背景

关于背景渐变,我是从b站中看到的,原理就是一个普通的css样式,并没有什么特别。

background-image: linear-gradient(to bottom right, #FC466B, #3F5EFB);

el中切割线的样式修改

在使用element-ui的<el-divider/>,他本身会有一些默认设置的样式,可以通过设置.el-divider这个css属性。

.el-divider {
    height: 180px;
    margin: 0 0 0 100%;
}

Vue路由跳转传递对象参数

关于vue路由跳转传递参数有许多种情况。这个网上有许多的教程,我就不只是记录我使用的方式,更多可以看推荐博客:https://blog.csdn.net/qq_38244874/article/details/110390047

Vue深度选择器修改样式

通过/deep/ 来深度修改,在前面加个class,在需要改的标签中引用class,就可以对指定的进行修改,如下所示:

.newDialog /deep/ .el-dialog__header {
  padding: 1vh 1vw 0 1vw;
}
.newDialog /deep/ .el-dialog__body {
  padding: 1vh 1vw;
}

vue 生命周期 beforeDestroy 和 destroyed 调用

  • 情境一:离开当前路由,会直接调用;

当前路由不使用 缓存,离开当前路由会直接调用 beforeDestroy 和 destroyed 销毁

  • 情景二:离开当前路由,不会直接调用,需要程序控制调用;

当前路由使用 缓存,离开当前路由不会直接调用 beforeDestroy 和 destroyed 销毁,需要使用路由钩子函数主动的调用

beforeRouteLeave(to, from, next) {
  this.$destroy();
  next();
}

定时任务

关于定时任务也是十分简单的

创建定时任务

this.timer = setInterval(() => { // 定时刷新设备的状态信息
  console.log('定时任务启动')
}, 5000)

销毁定时任务

beforeDestroy() {
  // js提供的clearInterval方法用来清除定时器
  console.log('定时任务销毁')
  clearInterval(this.timer)
}

单独校验

例子如下:

<el-table-columnlabel="编码"prop="code"min-width="120"><templateslot-scope="scope"><el-form-item:prop="'gridFieldData.'+ scope.$index + '.code'":rules="[{ required: true, message: '编码不能为空!', trigger: 'blur' }]"><el-inputv-model="scope.row.code"/></el-form-item></template></el-table-column>

async与await的关系

在使用vue中如果返回的值是一个Promise对象,那我们就可以用async和await简化这段代码

async是作为一个关键词放在函数的最前面,而await是放在async函数里面的,async表示这个函数是异步的,await是等待的意思,它的后面我们一般都放返回值是一个Promise对象的函数。

使用async函数返回的一定是个Promise对象,而await的作用就是等待这个对象执行完毕,并且接收到返回值的时候才会继续执行下一步,在此之前就像暂停了一样,没有接收到返回值是不会进行下一步的,但是它在等待的时候并没有妨碍async函数外面的代码执行。

事件的监听与销毁

在生命周期调用removeEventListener方法即可

mounted() {
  window.addEventListener('scroll', this.handleScroll)
},
beforeDestroy() {
  window.removeEventListener('scroll', this.handleScroll)
},

文本过长自动换行显示

添加css样式即可

https://developer.mozilla.org/en-US/docs/Web/CSS/word-break

.text-wrapper {
  word-break: break-all;
  word-wrap: break-word;
}

👍创作不易,如有错误请指正,感谢观看!记得点赞哦!👍

相关文章
|
5天前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
|
5天前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
17 0
|
5天前
|
人工智能 自然语言处理 运维
前端大模型应用笔记(一):两个指令反过来说大模型就理解不了啦?或许该让第三者插足啦 -通过引入中间LLM预处理用户输入以提高多任务处理能力
本文探讨了在多任务处理场景下,自然语言指令解析的困境及解决方案。通过增加一个LLM解析层,将复杂的指令拆解为多个明确的步骤,明确操作类型与对象识别,处理任务依赖关系,并将自然语言转化为具体的工具命令,从而提高指令解析的准确性和执行效率。
|
5天前
|
存储 弹性计算 算法
前端大模型应用笔记(四):如何在资源受限例如1核和1G内存的端侧或ECS上运行一个合适的向量存储库及如何优化
本文探讨了在资源受限的嵌入式设备(如1核处理器和1GB内存)上实现高效向量存储和检索的方法,旨在支持端侧大模型应用。文章分析了Annoy、HNSWLib、NMSLib、FLANN、VP-Trees和Lshbox等向量存储库的特点与适用场景,推荐Annoy作为多数情况下的首选方案,并提出了数据预处理、索引优化、查询优化等策略以提升性能。通过这些方法,即使在资源受限的环境中也能实现高效的向量检索。
|
5天前
|
机器学习/深度学习 弹性计算 自然语言处理
前端大模型应用笔记(二):最新llama3.2小参数版本1B的古董机测试 - 支持128K上下文,表现优异,和移动端更配
llama3.1支持128K上下文,6万字+输入,适用于多种场景。模型能力超出预期,但处理中文时需加中英翻译。测试显示,其英文支持较好,中文则需改进。llama3.2 1B参数量小,适合移动端和资源受限环境,可在阿里云2vCPU和4G ECS上运行。
|
5天前
|
前端开发 算法 测试技术
前端大模型应用笔记(五):大模型基础能力大比拼-计数篇-通义千文 vs 文心一言 vs 智谱 vs 讯飞vsGPT
本文对比测试了通义千文、文心一言、智谱和讯飞等多个国产大模型在处理基础计数问题上的表现,特别是通过链式推理(COT)提示的效果。结果显示,GPTo1-mini、文心一言3.5和讯飞4.0Ultra在首轮测试中表现优秀,而其他模型在COT提示后也能显著提升正确率,唯有讯飞4.0-Lite表现不佳。测试强调了COT在提升模型逻辑推理能力中的重要性,并指出免费版本中智谱GLM较为可靠。
前端大模型应用笔记(五):大模型基础能力大比拼-计数篇-通义千文 vs 文心一言 vs 智谱 vs 讯飞vsGPT
|
1月前
|
SpringCloudAlibaba JavaScript 前端开发
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
分布式组件、nacos注册配置中心、openfegin远程调用、网关gateway、ES6脚本语言规范、vue、elementUI
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
|
2月前
|
存储 前端开发 JavaScript
前端语言串讲 | 青训营笔记
前端语言串讲 | 青训营笔记
37 0
|
4月前
|
JSON 前端开发 JavaScript
前端Ajax、Axios和Fetch的用法和区别笔记
前端Ajax、Axios和Fetch的用法和区别笔记
84 2
|
4月前
|
前端开发 JavaScript 数据库
如何实现前后端分离-----前端笔记
如何实现前后端分离-----前端笔记