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.修改前后效果对比:

修改前:

修改后:

vue项目代码改进(一)login组件相关推荐

  1. Vue项目代码改进(六)—— vue的mixins的使用

    混入可以将不同组件的共同内容部分在一个混入对象中展示,然后通过在组件实例中混入这个对象,这样拥有这些属性的组件都可以调用 混入对象中的属性名跟组件中的属性名冲突时,以组件自身的为基准 举例:单文件组件 ...

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

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

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

    存在问题: 如果在退出页面时,没有点击"退出"按钮,而是直接关闭页面,token并没有被清除,依然能通过访问http://localhost:8080/#/ 直接进入主页. 原因: ...

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

    Message 消息提示 Options duration 显示时间, 毫秒.设为 0 则不会自动关闭 - 默认值3000 全局重写 element 的message 消息提示,修改时间,在main. ...

  5. Vue项目代码改进(五)—— 将侧边栏菜单改造为动态后,如何按需显示不同图标

    将侧边栏菜单改造为动态后,目前侧边栏每项的小图标都相同 <el-aside class="aside" width="200px"><el-c ...

  6. vue项目中element-ui的分页器(组件封装)

    vue项目中element-ui的分页器组件 <template><el-col :span="24" class="toolbar" sty ...

  7. vue项目代码格式不统一怎么办?一招教你解决

    vue项目代码风格统一 问题背景 方案分析 1.在package.json中增加prettier的依赖以及运行脚本 2.修改.eslintrc.js,去除所有vue-cli自动生成的规范,自定义插件及 ...

  8. 服务器上部署前端Vue项目代码

    服务器上部署前端Vue项目代码 本人自己感觉部署前端代码比部署后端难,主要是我在部署的过程中遇到了各种报错

  9. vue项目的骨架及常用组件介绍

    vue项目基础结构 一个vue的项目,我觉得最小的子集其实就是{vue,vue-router,component},vue作为基础库,为我们提供双向绑定等功能.vue-router连接不同的" ...

最新文章

  1. 上海交大 CDNet:基于YOLOv5改进的 人行道 斑马线和汽车过线行为检测
  2. python教程:sum(1-2+3-4+...+99)
  3. 记一次笑哭的unterminated string literal报错
  4. python使用get和post方法_python爬虫中get和post方法介绍以及cookie作用
  5. 循环的时候去删除集合中的元素 java.util.ConcurrentModificationException
  6. sprintf()、fprintf()的使用方法
  7. python+OpenCV图像处理(十一)图像轮廓检测
  8. 控制器发生异常 eofexception_关于气动薄膜调节阀常发生的故障你可能还不知道...
  9. MacBook的delete键使用技巧
  10. ai人工智能将替代人类_AI和人类如何优化空气污染监测
  11. 鸿蒙系统专利申请,华为在欧盟申请HarmonyOS专利 或为鸿蒙系统的英文名称
  12. php-fpm启动方式,php-fpm 的各种启动方式
  13. C#开发自己的Web服务器
  14. 小程序开发之【前端开发】【学习第二节】【一】
  15. 搭建我的世界java版服务器,公网远程联机【内网穿透】
  16. 360密盘两月即被破解 10万年成笑话
  17. 逻辑为基、数企赋能(NO.5)—逻辑思维层次
  18. 程序员宝爸:从处对象,结婚,怀孕到养娃持续攻略
  19. [健康]治疗偏头痛的六方
  20. 小猪的Python学习之旅 —— 18.Python微信转发小宇宙早报

热门文章

  1. 打开另外一个页面_如何在PDF页面中插入图片?
  2. python多线程为什么要用队列_Python程序中的线程操作-线程队列
  3. pandas输出到excel_python读写excel等数据文件方法汇总
  4. java设置属性的取值范围是多少_jvm-Java系统属性的范围
  5. Query意图分析:记一次完整的机器学习过程(scikit learn library学习笔记)
  6. nginx配置文件nginx.conf
  7. PaddlePaddle开源平台的应用
  8. 《第一行代码》学习笔记35-服务Service(2)
  9. 为什么“三次握手,四次挥手”?
  10. 解决:缺少aclocal、autoconf、automake