1、业务背景

还款业务,设置每月还款日,选每月几号扣款,不需要29、30、31,因为不是每个月都有这三天的

2、预期效果图

3、代码实现

3.1 初始化vue项目

地址:https://cn.vuejs.org/guide/introduction.html

3.2 在项目中应用elementUI

地址:https://element.eleme.io/#/zh-CN/component/installation

3.3 在main.js中引用

import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import App from './App'
import router from './router' Vue.use(ElementUI) new Vue({
el: '#app',
router,
components: { App },
template: '<App/>'
})

3.4 编写字母按钮组件(完整代码在最后)

<template>
<div class='box'>
<span
class='inner'
@click='selectClick(index, item)'
:class="'list_'+index"
v-for='(item, index) in numberArr'
:key='index'
>{{ item }}</span
>
</div>
</template>

3.5 引用字母按钮组件(完整代码在最后)

<template>
<div id="app">
<button @click="handleNumberClick">点击调用获取还款日组件方法</button>
<el-dialog
title="设置还款日"
append-to-body
:visible.sync="showDialog"
width="350px">
<number-select ref="numberSelect" :showDialog="showDialog" @hideModal="hideModal" />
</el-dialog>
<div>设置还款日期为{{this.sendNum}}</div>
</div>
</template>

4、实际效果图

5、完整代码

5.1 设置还款日组件页面 NumberSelect.vue

<!-- 设置还款日组件页面 NumberSelect.vue -->
<template>
<div class='box'>
<span
class='inner'
@click='selectClick(index, item)'
:class="'list_'+index"
v-for='(item, index) in numberArr'
:key='index'
>{{ item }}</span
>
</div>
</template> <script>
export default {
props: {
sendNumber: Number,
showDialog: {
type: Boolean,
default: false,
required: true // 必传递
}
},
name: 'numberSelect',
data () {
return {
numberArr: [],
index: 0
}
},
methods: {
// 选择按钮
selectClick (idx, item) {
this.sendNum = item
var len = this.numberArr.length
for (var i = 0; i < len; i++) {
if (i === idx) {
document.getElementsByClassName(
'list_' + i
)[0].style.backgroundColor = 'skyblue'
} else {
document.getElementsByClassName(
'list_' + i
)[0].style.backgroundColor = ''
}
}
this.$emit('hideModal')
}
},
// 创建28个字母按钮数组
created () {
for (var i = 1; i <= 28; i++) {
this.numberArr.push(i)
}
}
}
</script> <style>
.box {
margin: 0 auto;
background-color: #fff;
width: 300px;
height: 240px;
display: flex;
flex-wrap: wrap;
}
.inner {
margin-left: 10px;
margin-top: 10px;
text-align: center;
line-height: 30px;
width: 30px;
height: 30px;
border: 1px solid #000;
border-radius: 50%;
background-color: #fff;
display: inline-block;
cursor: pointer;
}
</style>

5.2 设置还款日组件页面 NumberSelect.vue

<template>
<div id="app">
<button @click="handleNumberClick">点击调用获取还款日组件方法</button>
<el-dialog
title="设置还款日"
append-to-body
:visible.sync="showDialog"
width="350px">
<number-select ref="numberSelect" :showDialog="showDialog" @hideModal="hideModal" />
</el-dialog>
<div>设置还款日期为{{this.sendNum}}</div>
</div>
</template> <script>
import NumberSelect from './components/NumberSelect.vue'
export default {
components: { NumberSelect },
name: 'App',
data () {
return {
showDialog: false, // 是否显示还款日组件
sendNum: 0 // 还款日组件选中的值
}
},
methods: {
// 点击设置还款日按钮
handleNumberClick () {
this.showDialog = true
},
// 关闭弹窗
hideModal () {
this.showDialog = false
console.log('确认的数字为:' + this.$refs.numberSelect.sendNum)
this.sendNum = this.$refs.numberSelect.sendNum
}
}
}
</script> <style>
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>

若本文有帮助到阅读本文的同学,欢迎点赞、关注、收藏,互相学习交流。

最新文章

  1. 【知识积累】使用Httpclient实现网页的爬取并保存至本地
  2. 下载Tomcat时Tomcat网站上的core和deployer的区别
  3. 登陆+注册(三层+sql语句)
  4. 转载java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.spinner/com.example.spinner.MainActivity}: java.lang.NullPointerException
  5. tableView尾部多处一部分空白高度
  6. [转]C++学习心得
  7. Powershell 执行外部命令
  8. FreeRTOS--堆内存管理
  9. python 高级部分
  10. HttpConnection
  11. JS快排
  12. CentOS 7.x,不重新编译 PHP,动态安装 imap 扩展
  13. hibernate的findByExample 外键参数查询解决方案
  14. ffmpeg 将jpg转为yuv
  15. 数据库和struts2的拦截器
  16. LOOP AT GROUP语法熟悉
  17. 【译】第五篇 Replication:事务复制-How it works
  18. Discuz论坛post登录C#源码
  19. viewDidAppear在何时调用?
  20. Vue项目中用的Jquery.js和easing.js做的抛物线

热门文章

  1. Linux系统安装 tftp服务 NFS服务
  2. 第2-4-5章 规则引擎Drools高级语法-业务规则管理系统-组件化-中台
  3. 零基础学习python的第一天整理——python的安装以及pycharm安装
  4. K8s架构|全面整理K8s的架构介绍
  5. 云原生架构(二)环境搭建(Mac上安装Docker+Kubernetes+Istio一条龙)
  6. troubleshoot:PVC动态扩容报错
  7. OpenJudge 1.8.11 图像旋转
  8. 关于 MySQL 嵌套子查询中,无法关联主表字段问题的折中解决方法
  9. RSA中用到的推导,笔记持续更新
  10. MongoDB - 副本集简介