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

相关文章

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h