小白分享:我的一次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

相关文章

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript