vue项目代码改进(一)login组件

Login登录组件

1. 新增登录头像(css样式回顾)

1)div.avatar
2)子绝父相定位,left…top…
3)border
4)placeholder
5)box-shadow

box-shadow: offset-x offset-y blur spread color inset;
参数解释:
[X轴偏移量]offset-x:必需,取值正负都可。offset-x水平阴影的位置。
[Y轴偏移量] offset-y:必需,取值正负都可。offset-y垂直阴影的位置。
[阴影模糊半径]blur:可选,只能取正值。blur-radius阴影模糊半径,0即无模糊效果,值越大阴影边缘越模糊。
[阴影扩展]spread:可选,取值正负都可。spread代表阴影的周长向四周扩展的尺寸,正值,阴影扩大,负值阴影缩小。
[阴影颜色]color:可选。阴影的颜色。如果不设置,浏览器会取默认颜色,通常是黑色,但各浏览器默认颜色有差异,建议不要省略。可以是rgb(250,0,0),也可以是有透明值的rgba(250,0,0,0.5)。
[投影方式]inset:可选。关键字,将外部投影(默认outset)改为内部投影。inset 阴影在背景之上,内容之下。

6)flex布局(添加重置按钮)

.login-wrap .login_btns { ---- 容器样式display: flex;justify-content: center;
}
.login-btn { ---- 项目样式flex-grow: 1;
}
<el-row class="login_btns"> ---- 容器<el-button type="primary" class="login-btn" @click="handleLogin">登录</el-button> ---- 项目<el-button type="info" class="login-btn" @click="handleLogin">重置</el-button>
</el-row>

以下6个属性设置在容器上。
flex-direction;
flex-wrap;
flex-flow;
align-items;
align-content;
justify-content :
①flex-start(默认值):左对齐
②flex-end:右对齐
③center:居中
④space-between:两端对齐,项目之间的间隔都相等
⑤space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

2. element-UI input组件参数

el-input
1.密码框:使用show-password属性
2.带 icon 的输入框:
1)prefix-icon 属性在 input 组件首部增加显示图标;
2)suffix-icon 属性在 input 组件尾部增加显示图标;
3)通过 slot 来放置图标
<i slot="prefix" class="el-input__icon el-icon-search"> </i>

flex布局参考

3. element-UI form组件

表单验证(对输入的用户名/密码做简单的长度/非空验证)

只需要通过 rules 属性传入约定的验证规则,并将 Form-Item 的 prop 属性设置为需校验的字段名即可。

<el-form 
:model="formdata" 
:rules="rules" 
ref="formdata"><el-form-item label="用户名" -- 给label绑定propprop="username"></el-form-item><el-row class="login_btns"><el-button @click="handleLogin('formdata')">登录</el-button><el-button @click="resetForm('formdata')">重置</el-button></el-row>
</el-form>
data中
rules: {username: [{ required: true, message: '请输入用户名', trigger: 'blur' },{ min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }],// 登录密码的校验规则password: [{ required: true, message: '请输入登录密码', trigger: 'blur' },{ min: 6, max: 15, message: '长度在 6 到 15 个字符', trigger: 'blur' }]
}
methods: {async handleLogin (formName) {this.$refs[formName].validate((valid) => {if (valid) {alert('submit!')} else {console.log('error submit!!')return false}})},resetForm (formName) {this.$refs[formName].resetFields()}
}

4.添加键盘按下事件,实现回车登录

问题一:当配置在el-input里,项目无法实现该效果
 <el-input v-model="formdata.password" @keyup.enter="handleLogin('formdata')"></el-input>

解决:
当我们在使用第三方库时,我们必须在@keyup.enter后面加一个native 来确保这个功能能够得到实现。

@keyup.enter.native="handleLogin('formdata')"
问题二:在键入输入框后,enter才有效果

解决:
应当全局监听enter键,把监听事件绑定到document上,而不是在input/button上

  created () {let that = thisdocument.onkeydown = function (e) {e = window.event || eif ((that.$route.path === '/login') && (e.keyCode === 13)) {// 验证在登录界面和按得键是回车键enterthat.handleLogin('formdata')// 登录函数}}
}

5.修改前后效果对比:

修改前:
login组件修改前效果
修改后:
在这里插入图片描述

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

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

相关文章

es6 --- set实现并集(Union)、交集(Intersect)和差集(Difference)

Set:类似于数组,但是成员的值都是唯一的 let a new Set([1, 2, 3]); let b new Set([4, 3, 2]);// 并集 let union new Set([...a, ...b]);// 交集 let intersect new Set([...a].filter(x > b.has(x)));// 差级 let difference new Set( [...a].filter(x > !b.has…

解析DBF文件

上周&#xff0c;公司给了许多DBF后缀的数据文件让我进行解析。 因为是DBF文件我发现mysql&#xff0c;和Oracle都能直接对DBF文件进行导入。在导入过程中发现这些数据库并不能识别这些文件。 通过百度找到了打开这种文件的软件Visual FoxPro、Access&#xff0c;用它们打开后出…

Scrum 冲刺 第一日

Scrum 冲刺 第一日 站立式会议燃尽图Alpha 阶段认领任务明日任务安排项目预期任务量成员贡献值计算规则今日贡献量参考资料站立式会议 返回目录 燃尽图 返回目录 Alpha 阶段认领任务 学号组员分工用时20162309邢天岳补充说明书&部分测试18h20162311张之睿编写代码20h201623…

浅析 NodeJs 的几种文件路径

Node 中的文件路径大概有 __dirname, __filename, process.cwd(), ./ 或者 ../&#xff0c;前三个都是绝对路径&#xff0c;为了便于比较&#xff0c;./ 和 ../ 我们通过 path.resolve(./)来转换为绝对路径。 先看一个简单的栗子&#xff1a; 假如我们有这样的文件结构&#xf…

Vue项目代码改进(二)—— element-UI的消息显示时间修改

Message 消息提示 Options duration 显示时间, 毫秒。设为 0 则不会自动关闭 — 默认值3000 全局重写 element 的message 消息提示,修改时间&#xff0c;在main.js里 Vue.prototype.$message function (msg) {ElementUI.Message(msg) } Vue.prototype.$message.success func…

es6 --- 使用node的memoryUsage检测WeakMap()

打开node命令行 $ node --expose-gc// --expose-gc:表示允许手动执行垃圾回收机制// 手动执行一次垃圾回收,保证获取的内存使用状态准确 > global.gc();// 查看内存占用的初始状态, > process.memoryUsage();可以发现初始用了4.7MB左右 // 创建一个WeakMap()实例wm >…

遍历字典

Python支持对字典的遍历&#xff0c;有多种遍历字典的方式&#xff1a;所有的键值对&#xff0c;键或者值。 遍历所有的键值对&#xff1a; people {name:winter, age:25, sex:man, }for key,value in people.items():print("\nkey:"key)print("value…

Flexbox 布局

Flexbox 是 flexible box 的简称&#xff08;愚人码头注&#xff1a;意思是“灵活的盒子容器”&#xff09;&#xff0c;是 CSS3 引入的新的布局模式。它决定了元素如何在页面上排列&#xff0c;使它们能在不同的屏幕尺寸和设备下可预测地展现出来。 它之所以被称为 Flexbox &a…

利用jQuery和bootstrap更改radio样式

<div class"container body-content"><div class"row"><div class"text-center col-xs-12"><h3>标题</h3><div class"well well-sm"><div class"btn-group" data-toggle"butto…

将markdown编译为HTML和PDF

使用gulp搭建markdown编译环境 1. 执行npm init 进行项目初始化得到package.json 2. 全局安装gulp &#xff1a;npm install gulp --global; 3. 在项目中安装gulp依赖&#xff1a;npm install gulp --save-dev; 4. 创建gulpfile.js文件设置任务&#xff1a; var gulp require…

捕获异常的两种方式

捕获异常的两种方式方法一 #codingutf-8 import systry:with open("ddd.txt", "r") as f:data f.read()print data except:err sys.exc_info()print errsys.exc_info()返回三元组&#xff0c;分别是&#xff0c;异常类型、异常值、异常追溯地址方法二 #c…

Vue项目代码改进(三)—— Cookie、LocalStorage和SessionStorage的使用

存在问题&#xff1a; 如果在退出页面时&#xff0c;没有点击“退出”按钮&#xff0c;而是直接关闭页面&#xff0c;token并没有被清除&#xff0c;依然能通过访问http://localhost:8080/#/ 直接进入主页。 原因&#xff1a; 使用了localStorage而非sessionStorage或Cookie 一…

es6 --- Proxy实例的get方法

写一个拦截函数,访问目标对象不存在属性时,会抛出不存在该属性的错误 如果存在该属性时,就返回其值. var person {name: "张三" };var proxy new Proxy(person, {get: function(target, property) {if (property in target) {return target[property];} else {thr…

webstorm前端常用快捷键

Ctrl / 行注释/取消行注释 Ctrl Shift / 块注释/取消块注释 Ctrl W 选择代码块&#xff0c;一般是增量选择 Ctrl Shift W 上个快捷键的回退&#xff0c;减量选择代码 Alt Q 上下文信息 A…

sql常识

1.UNION与UNION ALL的区别UNION去重且排序UNION ALL不去重不排序2.sql语句or与union all的执行效率比较:union all>union> in >or 用一张表更新另一张表&#xff1a; UPDATE ASET A1 B1, A2 B2, A3 B3FROM A LEFT JOIN B ON A.ID B.IDMS SQL SERVER的写法&#xf…

优秀导航网站收集

一纳米学习网站导航 泡面吧导航 纳威安全导航 设计师导航网址 优设图书导航 极客导航 大前端网址导航 前端导航 转载于:https://www.cnblogs.com/fazero/p/7976684.html

Vue项目代码改进(四)—— 在使用ElementUI时点击同一个路由,页面报错

这个不可描述的问题是&#xff1a;在使用ElementUI时点击同一个路由&#xff0c;页面报错。 错误代码如下&#xff1a; element-ui.common.js?ccbf:3339 NavigationDuplicated {_ name: "NavigationDuplicated", name: "NavigationDuplicated", message…

es6 --- Proxy的属性(get、set除外)

apply()&#xff1a; 拦截函数的调用、call和apply操作 var target function () { return I am the target;}; var handler {apply: function () {reuturn I am the proxy;} };var p new Proxy(target, handler); p(); // " I am the proxy"has(): 判断对象是否…

关于jQuery对象(类数组对象)以及DOM对象相互转化问题——[object Object]和[object HTMLInputElement]

之前在某官网课程上看有关jQuery和bootstrap的相关教程&#xff0c;有一节课是教我们如何制作价格菜单的按钮以及总价问题 选中按钮&#xff0c;按钮样式会发生变化&#xff0c;右上角价格会自动运算 6个菜单的html结构差不多&#xff0c;先贴出一个菜单的html&#xff0c;如下…

如何去掉bootstrap table中表格样式中横线竖线

修改之前&#xff0c;表格看上去比较拥挤&#xff0c;因为bootstrap table插件中自带斑马线表格样式&#xff0c;有横线和竖线分栏&#xff0c;现在我们不需要这些。应UI设计的要求&#xff0c;要去掉中间的横线和竖线&#xff0c;使用了修改需求中一种简单粗暴的修改方法&…