小白分享:我的一次Vue学习非寻常之路(章二)

2023-12-03 12:58

本文主要是介绍小白分享:我的一次Vue学习非寻常之路(章二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1、实践案例
    • 1.1、联动效果
    • 1.2、form自定义校验
    • 1.3、TimePicker组件默认值
  • 2、归纳总结

导读:坦白讲,我是Java服务端研发,只知道Vue这么个前端编程语言,未曾任何学习过,仅仅是个小白。但为何突然学习Vue呢,这得益于一次需求研发,无奈前端资源紧张,恰这次需求实现是面向运营端,非C端用户,产品可以接受自己自测,毕竟初期也仅是他负责这个模块的间断性周期数据维护。鉴于此,我尝试着是否可以自己实现这个模块,毕竟虽然不懂,但是可以模仿其他模块,有示例可以参考,实在搞不定也可以请教前端指教一番。鉴于此,花费几天完成该模块的功能实现(包括表格、表单、表单验证、弹出框等等),鉴于此,写此篇回顾自己的非寻常学习路线。

1、实践案例

在实现相关功能中,总会遇到相关交互上的体验设计,譬如联动效果、表单验证等等,借助于毕竟java出身,有一定编程语言基础,况且曾经也业余的开发过相关前端,毕竟那都是早期的jQuery,或者Bootstrap了,那就顺便介绍相关实践案例吧。

1.1、联动效果

场景
譬如实现,倘若选择【否】那就隐藏下面两个元素。怎么搞呢,想必传统我们采取把下面两行放在一个div中,然后设置其display:none,既然思路有了,那就搞呗。

<template lang="jade">.amount-configel-form(label-width='180px', :model="formData", :rules="rules", ref="form")el-form-item(label="是否限额", prop="amountLimited")el-radio-group(v-model="formData.amountLimited")el-radio(v-for="item in amountLimitedList", :key="item.code", :label="item.code") {{item.desc}}div(v-if="formData.amountLimited == 1")el-form-item(label="单笔限额", prop="singleLimit")el-input(type="text", v-model.trim="formData.singleLimit", placeholder="仅支持正整数", :maxlength="11")el-form-item(label="单日限额", prop="dailyLimit")el-input(type="text", v-model.trim="formData.dailyLimit", placeholder="仅支持正整数", :maxlength="11")                  el-form-itemel-button(type="primary", @click="submitForm") 保存el-button(type="default", @click="closeDialog") 关闭
</template>

如上代码,我们可以发现,我们可以借助于vuev:if指令,通过对formData.amountLimited的值改变从而控制div的display属性值。而formData.amountLimited的值,通过v-model指令注册给上面的radio元素绑定值,从而实现radio切换控制formData.amountLimited值的变化,进一步控制div的display属性。

1.2、form自定义校验

场景
从上图我们可以看到,我们想要实现数字校验。

通过查看Element UI文档,照着示例,摸索。代码如下:

data() {var checkNumber = (rule, value, callback) => {console.log(value)if (!value) {return callback(new Error(rule.name + '不能为空'));}else if(!(/^\d*$/.test(value))){return callback(new Error(rule.name + '仅支持正整数'))}else{return callback()}};return {formData: {amountLimited: "",singleLimit: "",dailyLimit: "",},rules: {amountLimited: [{required: true,message: "请选择",}],singleLimit: [{required: true,message: "仅支持正整数",trigger: "blur"},{name:"单笔限额",validator: checkNumber,trigger: "blur"}],dailyLimit: [{required: true,message: "仅支持正整数",trigger: "blur"},{name:"单日限额",validator: checkNumber,trigger: "blur"}],},amountLimitedList: []};

我们通过定义rules,设置每个字段的校验属性,其中required控制字段小红星效果,通过validator函数,自定义检验。

扩展阅读:https://element.eleme.cn/#/zh-CN/component/form

1.3、TimePicker组件默认值

在这里插入图片描述

如上图,当我们选择时间维度时,时间范围有默认值。

<template lang="jade">.time-configel-form(label-width='180px', :model="formData", :rules="rules", ref="form")el-form-item(label="是否限时", prop="timeLimited")el-radio-group(v-model="formData.timeLimited")el-radio(v-for="item in timeLimitedList", :key="item.code", :label="item.code") {{item.desc}}div(v-if="formData.timeLimited == 1")el-form-item(label="时间维度", prop="timeClassify")el-radio-group(v-model="formData.timeClassify")el-radio(v-for="item in timeClassifyList", :key="item.code", :label="item.code" @change="changeTimeClassify(item.code)") {{item.desc}}el-form-item(label="时间范围")<el-time-select v-model="formData.timeRangeStart" :picker-options="{start: '00:00',step: '00:01',end: '24:00'}" placeholder="选择时间"></el-time-select>  ~  <el-time-select v-model="formData.timeRangeEnd" :picker-options="{start: '00:00',step: '00:01',end: '24:00'}" placeholder="选择时间"></el-time-select>el-form-itemel-button(type="primary", @click="submitForm") 保存el-button(type="default", @click="closeDialog") 关闭
</template>

我们通过@change 指令为radio绑定事件

changeTimeClassify(code){this.formData.timeRangeStart = '00:00';this.formData.timeRangeEnd = '24:00';}

其实对于TimePicker ,倘若我们设置步长比如15分钟,但是就会导致无法定义自己的时间,无奈只得设置步长为00:01。

拓展阅读:https://element.eleme.cn/#/zh-CN/component/time-picker

2、归纳总结

总而言之,如果理解了Vue的设计思想,我们就可以很容易实现自己的功能,这相对于jQuery的操作Dom元素,差异还是蛮大的,最主要区别在于我们通过为HTML元素,借助于Vue的相关指令,控制HTML的属性值变化,从而实现HTML元素的相关交互效果,如果理解了数据的双向绑定思想,我们就可以快速实现一个自己模块了。

下面的是我的公众号二维码图片,欢迎关注,或公众号搜索【秋夜无霜】。
秋夜无霜

这篇关于小白分享:我的一次Vue学习非寻常之路(章二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

MySQL8.2.0安装教程分享

《MySQL8.2.0安装教程分享》这篇文章详细介绍了如何在Windows系统上安装MySQL数据库软件,包括下载、安装、配置和设置环境变量的步骤... 目录mysql的安装图文1.python访问网址2javascript.点击3.进入Downloads向下滑动4.选择Community Server5.

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

10个Python自动化办公的脚本分享

《10个Python自动化办公的脚本分享》在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的Python自动化办公案例及源码,希望对大家有所帮助... 目录1. 批量处理 Excel 文件2. 自动发送邮件3. 批量重命名文件4. 数据清洗5. 生成 PPT6. 自动化测试