mirror of
				https://github.com/yangzongzhuan/RuoYi-Vue.git
				synced 2025-10-24 19:32:05 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			115 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | ||
| 	<el-form size='small'>
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="1">
 | ||
| 				月,允许的通配符[, - * /]
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="2">
 | ||
| 				周期从
 | ||
| 				<el-input-number v-model='cycle01' :min="1" :max="12" /> -
 | ||
| 				<el-input-number v-model='cycle02' :min="1" :max="12" /> 月
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="3">
 | ||
| 				从
 | ||
| 				<el-input-number v-model='average01' :min="1" :max="12" /> 月开始,每
 | ||
| 				<el-input-number v-model='average02' :min="1" :max="12" /> 月月执行一次
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 
 | ||
| 		<el-form-item>
 | ||
| 			<el-radio v-model='radioValue' :label="4">
 | ||
| 				指定
 | ||
| 				<el-select clearable v-model="checkboxList" placeholder="可多选" multiple style="width:100%">
 | ||
| 					<el-option v-for="item in 12" :key="item" :value="item">{{item}}</el-option>
 | ||
| 				</el-select>
 | ||
| 			</el-radio>
 | ||
| 		</el-form-item>
 | ||
| 	</el-form>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| export default {
 | ||
| 	data() {
 | ||
| 		return {
 | ||
| 			radioValue: 1,
 | ||
| 			cycle01: 1,
 | ||
| 			cycle02: 2,
 | ||
| 			average01: 1,
 | ||
| 			average02: 1,
 | ||
| 			checkboxList: [],
 | ||
| 			checkNum: this.check
 | ||
| 		}
 | ||
| 	},
 | ||
| 	name: 'crontab-month',
 | ||
| 	props: ['check', 'cron'],
 | ||
| 	methods: {
 | ||
| 		// 单选按钮值变化时
 | ||
| 		radioChange() {
 | ||
| 			switch (this.radioValue) {
 | ||
| 				case 1:
 | ||
| 					this.$emit('update', 'month', '*');
 | ||
| 					break;
 | ||
| 				case 2:
 | ||
| 					this.$emit('update', 'month', this.cycle01 + '-' + this.cycle02);
 | ||
| 					break;
 | ||
| 				case 3:
 | ||
| 					this.$emit('update', 'month', this.average01 + '/' + this.average02);
 | ||
| 					break;
 | ||
| 				case 4:
 | ||
| 					this.$emit('update', 'month', this.checkboxString);
 | ||
| 					break;
 | ||
| 			}
 | ||
| 		},
 | ||
| 		// 周期两个值变化时
 | ||
| 		cycleChange() {
 | ||
| 			if (this.radioValue == '2') {
 | ||
| 				this.$emit('update', 'month', this.cycleTotal);
 | ||
| 			}
 | ||
| 		},
 | ||
| 		// 平均两个值变化时
 | ||
| 		averageChange() {
 | ||
| 			if (this.radioValue == '3') {
 | ||
| 				this.$emit('update', 'month', this.averageTotal);
 | ||
| 			}
 | ||
| 		},
 | ||
| 		// checkbox值变化时
 | ||
| 		checkboxChange() {
 | ||
| 			if (this.radioValue == '4') {
 | ||
| 				this.$emit('update', 'month', this.checkboxString);
 | ||
| 			}
 | ||
| 		}
 | ||
| 	},
 | ||
| 	watch: {
 | ||
| 		"radioValue": "radioChange",
 | ||
| 		'cycleTotal': 'cycleChange',
 | ||
| 		'averageTotal': 'averageChange',
 | ||
| 		'checkboxString': 'checkboxChange'
 | ||
| 	},
 | ||
| 	computed: {
 | ||
| 		// 计算两个周期值
 | ||
| 		cycleTotal: function () {
 | ||
| 			this.cycle01 = this.checkNum(this.cycle01, 1, 12)
 | ||
| 			this.cycle02 = this.checkNum(this.cycle02, 1, 12)
 | ||
| 			return this.cycle01 + '-' + this.cycle02;
 | ||
| 		},
 | ||
| 		// 计算平均用到的值
 | ||
| 		averageTotal: function () {
 | ||
| 			this.average01 = this.checkNum(this.average01, 1, 12)
 | ||
| 			this.average02 = this.checkNum(this.average02, 1, 12)
 | ||
| 			return this.average01 + '/' + this.average02;
 | ||
| 		},
 | ||
| 		// 计算勾选的checkbox值合集
 | ||
| 		checkboxString: function () {
 | ||
| 			let str = this.checkboxList.join();
 | ||
| 			return str == '' ? '*' : str;
 | ||
| 		}
 | ||
| 	}
 | ||
| }
 | ||
| </script>
 | 
