1.首先需要npm下载
npm install cron-parser 和npm install debounce 和npm install iview
2.在main.js中引入
import iView from 'iview'
import 'iview/dist/styles/iview.css'
Vue.use(iView)
3.新建一个components文件夹,里面放年月日时分秒周的数据
3-1.新建一个const.js文件
export const WEEK_MAP_EN = {
'SUN': '0',
'MON': '1',
'TUE': '2',
'WED': '3',
'THU': '4',
'FRI': '5',
'SAT': '6'
}
export const replaceWeekName = (c) => {
// console.info('after: ' + c)
if (c) {
Object.keys(WEEK_MAP_EN).forEach(k => {
c = c.replace(new RegExp(k, 'g'), WEEK_MAP_EN[k])
})
c = c.replace(new RegExp('7', 'g'), '0')
}
// console.info('after: ' + c)
return c
}
3-2.新建一个day.vue文件
<template>
<div class="config-list">
<RadioGroup v-model="type">
<div class="item">
<Radio label="TYPE_NOT_SET" class="choice" :disabled="disableChoice">不设置</Radio>
<span class="tip-info">日和周只能设置其中之一</span>
</div>
<div class="item">
<Radio label="TYPE_EVERY" class="choice" :disabled="disableChoice">每日</Radio>
</div>
<div class="item">
<Radio label="TYPE_RANGE" class="choice" :disabled="disableChoice">区间</Radio>
从<InputNumber :disabled="type!=TYPE_RANGE || disableChoice" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueRange.start" />日
至<InputNumber :disabled="type!=TYPE_RANGE || disableChoice" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueRange.end" />日
</div>
<div class="item">
<Radio label="TYPE_LOOP" class="choice" :disabled="disableChoice">循环</Radio>
从<InputNumber :disabled="type!=TYPE_LOOP || disableChoice" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueLoop.start" />日开始,间隔
<InputNumber :disabled="type!=TYPE_LOOP || disableChoice" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueLoop.interval" />日
</div>
<div class="item">
<Radio label="TYPE_WORK" class="choice" :disabled="disableChoice">工作日</Radio>
本月<InputNumber :disabled="type!=TYPE_WORK || disableChoice" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueWork" />日,最近的工作日
</div>
<div class="item">
<Radio label="TYPE_LAST" class="choice" :disabled="disableChoice">最后一日</Radio>
</div>
<div class="item">
<Radio label="TYPE_SPECIFY" class="choice" :disabled="disableChoice">指定</Radio>
<div class="list">
<CheckboxGroup v-model="valueList">
<Checkbox class="list-check-item" v-for="i in maxValue"
:label="i" :key="`key-${i}`" :disabled="type!=TYPE_SPECIFY || disableChoice"></Checkbox>
</CheckboxGroup>
</div>
</div>
</RadioGroup>
</div>
</template>
<script>
import mixin from './mixin'
export default {
name: 'day',
mixins: [mixin],
props: {
week: {
type: String,
default: '?'
}
},
data () {
return {}
},
computed: {
disableChoice () {
return (this.week && this.week !== '?') || this.disabled
}
},
watch: {
value_c (newVal, oldVal) {
// 数值变化
this.updateValue()
},
week (newVal, oldVal) {
// console.info('new week: ' + newVal)
this.updateValue()
}
},
methods: {
updateValue () {
this.$emit('change', this.disableChoice ? '?' : this.value_c)
}
},
created () {
this.DEFAULT_VALUE = '*'
this.minValue = 1
this.maxValue = 31
this.valueRange.start = 1
this.valueRange.end = 31
this.valueLoop.start = 1
this.valueLoop.interval = 1
this.parseProp(this.prop)
}
}
</script>
<style scoped>
.config-list {
text-align: left;
margin: 0 10px 10px 10px;
}
.item {
margin-top: 5px;
}
.tip-info {
color: #999
}
.choice {
border: 1px solid transparent;
padding: 5px 8px;
}
.choice:hover {
border: 1px solid #2d8cf0;
}
.w60 {
width: 60px;
}
.ivu-input-number {
margin-left: 5px;
margin-right: 5px;
}
.list {
margin: 0 20px;
}
.list-check-item {
padding: 1px 3px;
width: 4em;
}
</style>
3-3.新建一个hour.vue文件
<template>
<div class="config-list">
<RadioGroup v-model="type">
<div class="item">
<Radio label="TYPE_EVERY" class="choice" :disabled="disabled">每时</Radio>
</div>
<div class="item">
<Radio label="TYPE_RANGE" class="choice" :disabled="disabled">区间</Radio>
从<InputNumber :disabled="type!=TYPE_RANGE || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueRange.start" />时
至<InputNumber :disabled="type!=TYPE_RANGE || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueRange.end" />时
</div>
<div class="item">
<Radio label="TYPE_LOOP" class="choice" :disabled="disabled">循环</Radio>
从<InputNumber :disabled="type!=TYPE_LOOP || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueLoop.start" />时开始,间隔
<InputNumber :disabled="type!=TYPE_LOOP || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueLoop.interval" />时
</div>
<div class="item">
<Radio label="TYPE_SPECIFY" class="choice" :disabled="disabled">指定</Radio>
<div class="list">
<CheckboxGroup v-model="valueList">
<Checkbox class="list-check-item" v-for="i in maxValue+1"
:label="i-1" :key="`key-${i-1}`" :disabled="type!=TYPE_SPECIFY || disabled"></Checkbox>
</CheckboxGroup>
</div>
</div>
</RadioGroup>
</div>
</template>
<script>
import mixin from './mixin'
export default {
name: 'minute',
mixins: [mixin],
data () {
return {}
},
watch: {
value_c (newVal, oldVal) {
this.$emit('change', newVal)
}
},
created () {
this.DEFAULT_VALUE = '*'
this.minValue = 0
this.maxValue = 23
this.valueRange.start = 0
this.valueRange.end = 23
this.valueLoop.start = 0
this.valueLoop.interval = 1
this.parseProp(this.prop)
}
}
</script>
<style scoped>
.config-list {
text-align: left;
margin: 0 10px 10px 10px;
}
.item {
margin-top: 5px;
}
.choice {
border: 1px solid transparent;
padding: 5px 8px;
}
.choice:hover {
border: 1px solid #2d8cf0;
}
.w60 {
width: 60px;
}
.ivu-input-number {
margin-left: 5px;
margin-right: 5px;
}
.list {
margin: 0 20px;
}
.list-check-item {
padding: 1px 3px;
width: 4em;
}
</style>
3-4.新建一个minute.vue文件
<template>
<div class="config-list">
<RadioGroup v-model="type">
<div class="item">
<Radio label="TYPE_EVERY" class="choice" :disabled="disabled">每分</Radio>
</div>
<div class="item">
<Radio label="TYPE_RANGE" class="choice" :disabled="disabled">区间</Radio>
从<InputNumber :disabled="type!=TYPE_RANGE || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueRange.start" />分
至<InputNumber :disabled="type!=TYPE_RANGE || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueRange.end" />分
</div>
<div class="item">
<Radio label="TYPE_LOOP" class="choice" :disabled="disabled">循环</Radio>
从<InputNumber :disabled="type!=TYPE_LOOP || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueLoop.start" />分开始,间隔
<InputNumber :disabled="type!=TYPE_LOOP || disabled" :max="maxValue" :min="minValue" :precision="0"
class="w60" v-model="valueLoop.interval" />分
</div>
<div class="item">
<Radio label="TYPE_SPECIFY" class="choice" :disabled="disabled">指定</Radio>
<div class="list">
<CheckboxGroup v-model="valueList">
<Checkbox class="list-check-item" v-for="i in maxValue+1"
:label="i-1" :key="`key-${i-1}`" :disabled="type!=TYPE_SPECIFY || disabled"></Checkbox>
</CheckboxGroup>
</div>
</div>
</Rad