首页 > 其他分享 >vue3cron表达式

vue3cron表达式

时间:2024-06-18 15:32:40浏览次数:8  
标签:arr return value else start vue3cron type 表达式

 


引用: js部分 import cmCron from '../../components/cmCron/index.vue';
const shortcuts= [           {             text: "每天8点和12点 (自定义追加)",             value: "0 0 8,12 * * ?"           }         ];  
模板部分:         <el-form-item prop="cronExpression" label="cron表达式">           <cm-cron v-model="dataForm.cronExpression" placeholder="请输入Cron定时规则" clearable :shortcuts="shortcuts"></cm-cron>
      </el-form-item>    
 

components/cmCron/index.vue内容如下:


 

 

<!--  * @Descripttion: cron规则生成器  * @version: 1.0  * @Author:  * @Date: 2021年12月29日15:23:54  * @LastEditors:  * @LastEditTime: -->
<template>     <el-input v-model="defaultValue" v-bind="$attrs">         <template #append>             <el-dropdown size="medium" @command="handleShortcuts">                 <el-button icon="el-icon-arrow-down"></el-button>                 <template #dropdown>                     <el-dropdown-menu>                         <el-dropdown-item command="0 * * * * ?">每分钟</el-dropdown-item>                         <el-dropdown-item command="0 0 * * * ?">每小时</el-dropdown-item>                         <el-dropdown-item command="0 0 0 * * ?">每天零点</el-dropdown-item>                         <el-dropdown-item command="0 0 0 1 * ?">每月一号零点</el-dropdown-item>                         <el-dropdown-item command="0 0 0 L * ?">每月最后一天零点</el-dropdown-item>                         <el-dropdown-item command="0 0 0 ? * 1">每周星期日零点</el-dropdown-item>                         <el-dropdown-item v-for="(item, index) in shortcuts" :key="item.value" :divided="index==0" :command="item.value">{{item.text}}</el-dropdown-item>                         <el-dropdown-item icon="el-icon-plus" divided command="custom">自定义</el-dropdown-item>                     </el-dropdown-menu>                 </template>             </el-dropdown>         </template>     </el-input>
    <el-dialog title="cron规则生成器" v-model="dialogVisible" :width="580" destroy-on-close append-to-body>         <div class="sa-cron">             <el-tabs>                 <el-tab-pane>                     <template #label>                         <div class="sa-cron-num">                             <h2>秒</h2>                             <h4>{{value_second}}</h4>                         </div>                     </template>                     <el-form>                         <el-form-item label="类型">                             <el-radio-group v-model="value.second.type">                                 <el-radio-button label="0">任意值</el-radio-button>                                 <el-radio-button label="1">范围</el-radio-button>                                 <el-radio-button label="2">间隔</el-radio-button>                                 <el-radio-button label="3">指定</el-radio-button>                             </el-radio-group>                         </el-form-item>                         <el-form-item label="范围" v-if="value.second.type==1">                             <el-input-number v-model="value.second.range.start" :min="0" :max="59" controls-position="right"></el-input-number>                             <span style="padding:0 15px;">-</span>                             <el-input-number v-model="value.second.range.end" :min="0" :max="59" controls-position="right"></el-input-number>                         </el-form-item>                         <el-form-item label="间隔" v-if="value.second.type==2">                             <el-input-number v-model="value.second.loop.start" :min="0" :max="59" controls-position="right"></el-input-number>                             秒开始,每                             <el-input-number v-model="value.second.loop.end" :min="0" :max="59" controls-position="right"></el-input-number>                             秒执行一次                         </el-form-item>                         <el-form-item label="指定" v-if="value.second.type==3">                             <el-select v-model="value.second.appoint" multiple style="width: 100%;">                                 <el-option v-for="(item, index) in data.second" :key="index" :label="item" :value="item"></el-option>                             </el-select>                         </el-form-item>                     </el-form>                 </el-tab-pane>                 <el-tab-pane>                     <template #label>                         <div class="sa-cron-num">                             <h2>分钟</h2>                             <h4>{{value_minute}}</h4>                         </div>                     </template>                     <el-form>                         <el-form-item label="类型">                             <el-radio-group v-model="value.minute.type">                                 <el-radio-button label="0">任意值</el-radio-button>                                 <el-radio-button label="1">范围</el-radio-button>                                 <el-radio-button label="2">间隔</el-radio-button>                                 <el-radio-button label="3">指定</el-radio-button>                             </el-radio-group>                         </el-form-item>                         <el-form-item label="范围" v-if="value.minute.type==1">                             <el-input-number v-model="value.minute.range.start" :min="0" :max="59" controls-position="right"></el-input-number>                             <span style="padding:0 15px;">-</span>                             <el-input-number v-model="value.minute.range.end" :min="0" :max="59" controls-position="right"></el-input-number>                         </el-form-item>                         <el-form-item label="间隔" v-if="value.minute.type==2">                             <el-input-number v-model="value.minute.loop.start" :min="0" :max="59" controls-position="right"></el-input-number>                             分钟开始,每                             <el-input-number v-model="value.minute.loop.end" :min="0" :max="59" controls-position="right"></el-input-number>                             分钟执行一次                         </el-form-item>                         <el-form-item label="指定" v-if="value.minute.type==3">                             <el-select v-model="value.minute.appoint" multiple style="width: 100%;">                                 <el-option v-for="(item, index) in data.minute" :key="index" :label="item" :value="item"></el-option>                             </el-select>                         </el-form-item>                     </el-form>                 </el-tab-pane>                 <el-tab-pane>                     <template #label>                         <div class="sa-cron-num">                             <h2>小时</h2>                             <h4>{{value_hour}}</h4>                         </div>                     </template>                     <el-form>                         <el-form-item label="类型">                             <el-radio-group v-model="value.hour.type">                                 <el-radio-button label="0">任意值</el-radio-button>                                 <el-radio-button label="1">范围</el-radio-button>                                 <el-radio-button label="2">间隔</el-radio-button>                                 <el-radio-button label="3">指定</el-radio-button>                             </el-radio-group>                         </el-form-item>                         <el-form-item label="范围" v-if="value.hour.type==1">                             <el-input-number v-model="value.hour.range.start" :min="0" :max="23" controls-position="right"></el-input-number>                             <span style="padding:0 15px;">-</span>                             <el-input-number v-model="value.hour.range.end" :min="0" :max="23" controls-position="right"></el-input-number>                         </el-form-item>                         <el-form-item label="间隔" v-if="value.hour.type==2">                             <el-input-number v-model="value.hour.loop.start" :min="0" :max="23" controls-position="right"></el-input-number>                             小时开始,每                             <el-input-number v-model="value.hour.loop.end" :min="0" :max="23" controls-position="right"></el-input-number>                             小时执行一次                         </el-form-item>                         <el-form-item label="指定" v-if="value.hour.type==3">                             <el-select v-model="value.hour.appoint" multiple style="width: 100%;">                                 <el-option v-for="(item, index) in data.hour" :key="index" :label="item" :value="item"></el-option>                             </el-select>                         </el-form-item>                     </el-form>                 </el-tab-pane>                 <el-tab-pane>                     <template #label>                         <div class="sa-cron-num">                             <h2>日</h2>                             <h4>{{value_day}}</h4>                         </div>                     </template>                     <el-form>                         <el-form-item label="类型">                             <el-radio-group v-model="value.day.type">                                 <el-radio-button label="0">任意值</el-radio-button>                                 <el-radio-button label="1">范围</el-radio-button>                                 <el-radio-button label="2">间隔</el-radio-button>                                 <el-radio-button label="3">指定</el-radio-button>                                 <el-radio-button label="4">本月最后一天</el-radio-button>                                 <el-radio-button label="5">不指定</el-radio-button>                             </el-radio-group>                         </el-form-item>                         <el-form-item label="范围" v-if="value.day.type==1">                             <el-input-number v-model="value.day.range.start" :min="1" :max="31" controls-position="right"></el-input-number>                             <span style="padding:0 15px;">-</span>                             <el-input-number v-model="value.day.range.end" :min="1" :max="31" controls-position="right"></el-input-number>                         </el-form-item>                         <el-form-item label="间隔" v-if="value.day.type==2">                             <el-input-number v-model="value.day.loop.start" :min="1" :max="31" controls-position="right"></el-input-number>                             号开始,每                             <el-input-number v-model="value.day.loop.end" :min="1" :max="31" controls-position="right"></el-input-number>                             天执行一次                         </el-form-item>                         <el-form-item label="指定" v-if="value.day.type==3">                             <el-select v-model="value.day.appoint" multiple style="width: 100%;">                                 <el-option v-for="(item, index) in data.day" :key="index" :label="item" :value="item"></el-option>                             </el-select>                         </el-form-item>                     </el-form>                 </el-tab-pane>                 <el-tab-pane>                     <template #label>                         <div class="sa-cron-num">                             <h2>月</h2>                             <h4>{{value_month}}</h4>                         </div>                     </template>                     <el-form>                         <el-form-item label="类型">                             <el-radio-group v-model="value.month.type">                                 <el-radio-button label="0">任意值</el-radio-button>                                 <el-radio-button label="1">范围</el-radio-button>                                 <el-radio-button label="2">间隔</el-radio-button>                                 <el-radio-button label="3">指定</el-radio-button>                             </el-radio-group>                         </el-form-item>                         <el-form-item label="范围" v-if="value.month.type==1">                             <el-input-number v-model="value.month.range.start" :min="1" :max="12" controls-position="right"></el-input-number>                             <span style="padding:0 15px;">-</span>                             <el-input-number v-model="value.month.range.end" :min="1" :max="12" controls-position="right"></el-input-number>                         </el-form-item>                         <el-form-item label="间隔" v-if="value.month.type==2">                             <el-input-number v-model="value.month.loop.start" :min="1" :max="12" controls-position="right"></el-input-number>                             月开始,每                             <el-input-number v-model="value.month.loop.end" :min="1" :max="12" controls-position="right"></el-input-number>                             月执行一次                         </el-form-item>                         <el-form-item label="指定" v-if="value.month.type==3">                             <el-select v-model="value.month.appoint" multiple style="width: 100%;">                                 <el-option v-for="(item, index) in data.month" :key="index" :label="item" :value="item"></el-option>                             </el-select>                         </el-form-item>                     </el-form>                 </el-tab-pane>                 <el-tab-pane>                     <template #label>                         <div class="sa-cron-num">                             <h2>周</h2>                             <h4>{{value_week}}</h4>                         </div>                     </template>                     <el-form>                         <el-form>                             <el-form-item label="类型">                                 <el-radio-group v-model="value.week.type">                                     <el-radio-button label="0">任意值</el-radio-button>                                     <el-radio-button label="1">范围</el-radio-button>                                     <el-radio-button label="2">间隔</el-radio-button>                                     <el-radio-button label="3">指定</el-radio-button>                                     <el-radio-button label="4">本月最后一周</el-radio-button>                                     <el-radio-button label="5">不指定</el-radio-button>                                 </el-radio-group>                             </el-form-item>                             <el-form-item label="范围" v-if="value.week.type==1">                                 <el-select v-model="value.week.range.start">                                     <el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>                                 </el-select>                                 <span style="padding:0 15px;">-</span>                                 <el-select v-model="value.week.range.end">                                     <el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>                                 </el-select>                             </el-form-item>                             <el-form-item label="间隔" v-if="value.week.type==2">                                 第                                 <el-input-number v-model="value.week.loop.start" :min="1" :max="4" controls-position="right"></el-input-number>                                 周的星期                                 <el-select v-model="value.week.loop.end">                                     <el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>                                 </el-select>                                 执行一次                             </el-form-item>                             <el-form-item label="指定" v-if="value.week.type==3">                                 <el-select v-model="value.week.appoint" multiple style="width: 100%;">                                     <el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>                                 </el-select>                             </el-form-item>                             <el-form-item label="最后一周" v-if="value.week.type==4">                                 <el-select v-model="value.week.last">                                     <el-option v-for="(item, index) in data.week" :key="index" :label="item.label" :value="item.value"></el-option>                                 </el-select>                             </el-form-item>                         </el-form>                     </el-form>                 </el-tab-pane>                 <el-tab-pane>                     <template #label>                         <div class="sa-cron-num">                             <h2>年</h2>                             <h4>{{value_year}}</h4>                         </div>                     </template>                     <el-form>                         <el-form-item label="类型">                             <el-radio-group v-model="value.year.type">                                 <el-radio-button label="-1">忽略</el-radio-button>                                 <el-radio-button label="0">任意值</el-radio-button>                                 <el-radio-button label="1">范围</el-radio-button>                                 <el-radio-button label="2">间隔</el-radio-button>                                 <el-radio-button label="3">指定</el-radio-button>                             </el-radio-group>                         </el-form-item>                         <el-form-item label="范围" v-if="value.year.type==1">                             <el-input-number v-model="value.year.range.start" controls-position="right"></el-input-number>                             <span style="padding:0 15px;">-</span>                             <el-input-number v-model="value.year.range.end" controls-position="right"></el-input-number>                         </el-form-item>                         <el-form-item label="间隔" v-if="value.year.type==2">                             <el-input-number v-model="value.year.loop.start" controls-position="right"></el-input-number>                             年开始,每                             <el-input-number v-model="value.year.loop.end" :min="1" controls-position="right"></el-input-number>                             年执行一次                         </el-form-item>                         <el-form-item label="指定" v-if="value.year.type==3">                             <el-select v-model="value.year.appoint" multiple style="width: 100%;">                                 <el-option v-for="(item, index) in data.year" :key="index" :label="item" :value="item"></el-option>                             </el-select>                         </el-form-item>                     </el-form>                 </el-tab-pane>             </el-tabs>         </div>
        <template #footer>             <el-button @click="dialogVisible=false" >取 消</el-button>             <el-button type="primary" @click="submit()">确 认</el-button>         </template>     </el-dialog> </template>
<script>     export default {         props: {             modelValue: { type: String, default: "* * * * * ?" },             shortcuts: { type: Array, default: () => [] }         },         data() {             return {                 type: '0',                 defaultValue: '',                 dialogVisible: false,
                value:{                     second: {                         type: '0',                         range: {                             start: 1,                             end: 2                         },                         loop: {                             start: 0,                             end: 1                         },                         appoint: []                     },                     minute: {                         type: '0',                         range: {                             start: 1,                             end: 2                         },                         loop: {                             start: 0,                             end: 1                         },                         appoint: []                     },                     hour: {                         type: '0',                         range: {                             start: 1,                             end: 2                         },                         loop: {                             start: 0,                             end: 1                         },                         appoint: []                     },                     day: {                         type: '0',                         range: {                             start: 1,                             end: 2                         },                         loop: {                             start: 1,                             end: 1                         },                         appoint: []                     },                     month: {                         type: '0',                         range: {                             start: 1,                             end: 2                         },                         loop: {                             start: 1,                             end: 1                         },                         appoint: []                     },                     week: {                         type: '5',                         range: {                             start: '2',                             end: '3'                         },                         loop: {                             start: 0,                             end: '2'                         },                         last: '2',                         appoint: []                     },                     year: {                         type: '-1',                         range: {                             start: this.getYear()[0],                             end: this.getYear()[1]                         },                         loop: {                             start: this.getYear()[0],                             end: 1                         },                         appoint: []                     }                 },                 data: {                     second: ['0','5','15','20','25','30','35','40','45','50','55','59'],                     minute: ['0','5','15','20','25','30','35','40','45','50','55','59'],                     hour: ['0','1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17','18','19','20','21','22','23'],                     day: ['1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17','18','19','20','21','22','23','24','25','26','27','28','29','30','31'],                     month: ['1','2','3','4','5','6','7','8','9','10','11','12'],                     week: [                         {                             value: '1',                             label: '周日'                         },                         {                             value: '2',                             label: '周一'                         },                         {                             value: '3',                             label: '周二'                         },                         {                             value: '4',                             label: '周三'                         },                         {                             value: '5',                             label: '周四'                         },                         {                             value: '6',                             label: '周五'                         },                         {                             value: '7',                             label: '周六'                         }                     ],                     year: this.getYear()                 }             }         },         watch: {             'value.week.type'(val){                 if(val != '5'){                     this.value.day.type = '5'                 }             },             'value.day.type'(val){                 if(val != '5'){                     this.value.week.type = '5'                 }             },             modelValue() {                 this.defaultValue = this.modelValue             }         },         computed: {             value_second(){                 let v = this.value.second                 if(v.type == 0){                     return '*'                 }else if(v.type==1){                     return v.range.start + '-' +v.range.end                 }else if(v.type==2){                     return v.loop.start + '/' + v.loop.end                 }else if(v.type==3){                     return v.appoint.length>0 ? v.appoint.join(',') : '*'                 }else{                     return '*'                 }             },             value_minute(){                 let v = this.value.minute                 if(v.type == 0){                     return '*'                 }else if(v.type==1){                     return v.range.start + '-' +v.range.end                 }else if(v.type==2){                     return v.loop.start + '/' + v.loop.end                 }else if(v.type==3){                     return v.appoint.length>0 ? v.appoint.join(',') : '*'                 }else{                     return '*'                 }             },             value_hour(){                 let v = this.value.hour                 if(v.type == 0){                     return '*'                 }else if(v.type==1){                     return v.range.start + '-' +v.range.end                 }else if(v.type==2){                     return v.loop.start + '/' + v.loop.end                 }else if(v.type==3){                     return v.appoint.length>0 ? v.appoint.join(',') : '*'                 }else{                     return '*'                 }             },             value_day(){                 let v = this.value.day                 if(v.type == 0){                     return '*'                 }else if(v.type==1){                     return v.range.start + '-' +v.range.end                 }else if(v.type==2){                     return v.loop.start + '/' + v.loop.end                 }else if(v.type==3){                     return v.appoint.length>0 ? v.appoint.join(',') : '*'                 }else if(v.type==4){                     return 'L'                 }else if(v.type==5){                     return '?'                 }else{                     return '*'                 }             },             value_month(){                 let v = this.value.month                 if(v.type == 0){                     return '*'                 }else if(v.type==1){                     return v.range.start + '-' +v.range.end                 }else if(v.type==2){                     return v.loop.start + '/' + v.loop.end                 }else if(v.type==3){                     return v.appoint.length>0 ? v.appoint.join(',') : '*'                 }else{                     return '*'                 }             },             value_week(){                 let v = this.value.week                 if(v.type == 0){                     return '*'                 }else if(v.type==1){                     return v.range.start + '-' +v.range.end                 }else if(v.type==2){                     return v.loop.end + '#' + v.loop.start                 }else if(v.type==3){                     return v.appoint.length>0 ? v.appoint.join(',') : '*'                 }else if(v.type==4){                     return v.last + 'L'                 }else if(v.type==5){                     return '?'                 }else{                     return '*'                 }             },             value_year(){                 let v = this.value.year                 if(v.type == -1){                     return ''                 }else if(v.type==0){                     return '*'                 }else if(v.type==1){                     return v.range.start + '-' +v.range.end                 }else if(v.type==2){                     return v.loop.start + '/' + v.loop.end                 }else if(v.type==3){                     return v.appoint.length>0 ? v.appoint.join(',') : ''                 }else{                     return ''                 }             },         },         mounted() {             this.defaultValue = this.modelValue         },         methods: {             handleShortcuts(command){                 if(command == 'custom'){                     this.open()                 }else{                     this.defaultValue = command                     this.$emit('update:modelValue', this.defaultValue)                 }             },             open(){                 this.set()                 this.dialogVisible = true             },             set(){                 this.defaultValue = this.modelValue                 let arr = (this.modelValue || "* * * * * ?").split(" ")                 //简单检查                 if(arr.length < 6){                     this.$message.warning("cron表达式错误,已转换为默认表达式")                     arr = "* * * * * ?".split(" ")                 }
                //秒                 if(arr[0]=='*'){                     this.value.second.type = '0'                 }else if(arr[0].includes('-')){                     this.value.second.type = '1'                     this.value.second.range.start = Number(arr[0].split("-")[0])                     this.value.second.range.end = Number(arr[0].split("-")[1])                 }else if(arr[0].includes('/')){                     this.value.second.type = '2'                     this.value.second.loop.start = Number(arr[0].split("/")[0])                     this.value.second.loop.end = Number(arr[0].split("/")[1])                 }else{                     this.value.second.type = '3'                     this.value.second.appoint = arr[0].split(",")                 }                 //分                 if(arr[1]=='*'){                     this.value.minute.type = '0'                 }else if(arr[1].includes('-')){                     this.value.minute.type = '1'                     this.value.minute.range.start = Number(arr[1].split("-")[0])                     this.value.minute.range.end = Number(arr[1].split("-")[1])                 }else if(arr[1].includes('/')){                     this.value.minute.type = '2'                     this.value.minute.loop.start = Number(arr[1].split("/")[0])                     this.value.minute.loop.end = Number(arr[1].split("/")[1])                 }else{                     this.value.minute.type = '3'                     this.value.minute.appoint = arr[1].split(",")                 }                 //小时                 if(arr[2]=='*'){                     this.value.hour.type = '0'                 }else if(arr[2].includes('-')){                     this.value.hour.type = '1'                     this.value.hour.range.start = Number(arr[2].split("-")[0])                     this.value.hour.range.end = Number(arr[2].split("-")[1])                 }else if(arr[2].includes('/')){                     this.value.hour.type = '2'                     this.value.hour.loop.start = Number(arr[2].split("/")[0])                     this.value.hour.loop.end = Number(arr[2].split("/")[1])                 }else{                     this.value.hour.type = '3'                     this.value.hour.appoint = arr[2].split(",")                 }                 //日                 if(arr[3]=='*'){                     this.value.day.type = '0'                 }else if(arr[3]=='L'){                     this.value.day.type = '4'                 }else if(arr[3]=='?'){                     this.value.day.type = '5'                 }else if(arr[3].includes('-')){                     this.value.day.type = '1'                     this.value.day.range.start = Number(arr[3].split("-")[0])                     this.value.day.range.end = Number(arr[3].split("-")[1])                 }else if(arr[3].includes('/')){                     this.value.day.type = '2'                     this.value.day.loop.start = Number(arr[3].split("/")[0])                     this.value.day.loop.end = Number(arr[3].split("/")[1])                 }else{                     this.value.day.type = '3'                     this.value.day.appoint = arr[3].split(",")                 }                 //月                 if(arr[4]=='*'){                     this.value.month.type = '0'                 }else if(arr[4].includes('-')){                     this.value.month.type = '1'                     this.value.month.range.start = Number(arr[4].split("-")[0])                     this.value.month.range.end = Number(arr[4].split("-")[1])                 }else if(arr[4].includes('/')){                     this.value.month.type = '2'                     this.value.month.loop.start = Number(arr[4].split("/")[0])                     this.value.month.loop.end = Number(arr[4].split("/")[1])                 }else{                     this.value.month.type = '3'                     this.value.month.appoint = arr[4].split(",")                 }                 //周                 if(arr[5]=='*'){                     this.value.week.type = '0'                 }else if(arr[5]=='?'){                     this.value.week.type = '5'                 }else if(arr[5].includes('-')){                     this.value.week.type = '1'                     this.value.week.range.start = arr[5].split("-")[0]                     this.value.week.range.end = arr[5].split("-")[1]                 }else if(arr[5].includes('#')){                     this.value.week.type = '2'                     this.value.week.loop.start = Number(arr[5].split("#")[1])                     this.value.week.loop.end = arr[5].split("#")[0]                 }else if(arr[5].includes('L')){                     this.value.week.type = '4'                     this.value.week.last = arr[5].split("L")[0]                 }else{                     this.value.week.type = '3'                     this.value.week.appoint = arr[5].split(",")                 }                 //年                 if(!arr[6]){                     this.value.year.type = '-1'                 }else if(arr[6]=='*'){                     this.value.year.type = '0'                 }else if(arr[6].includes('-')){                     this.value.year.type = '1'                     this.value.year.range.start = Number(arr[6].split("-")[0])                     this.value.year.range.end = Number(arr[6].split("-")[1])                 }else if(arr[6].includes('/')){                     this.value.year.type = '2'                     this.value.year.loop.start = Number(arr[6].split("/")[1])                     this.value.year.loop.end = Number(arr[6].split("/")[0])                 }else{                     this.value.year.type = '3'                     this.value.year.appoint = arr[6].split(",")                 }             },             getYear(){                 let v = []                 let y = new Date().getFullYear()                 for (let i = 0; i < 11; i++) {                     v.push(y+i)                 }                 return v             },             submit(){                 let year = this.value_year ? ' '+this.value_year : ''                 this.defaultValue = this.value_second + ' ' + this.value_minute + ' ' + this.value_hour + ' ' + this.value_day + ' ' + this.value_month + ' ' + this.value_week + year                 this.$emit('update:modelValue', this.defaultValue)                 this.dialogVisible = false             }         }     } </script>
<style scoped>     .sa-cron:deep(.el-tabs__item) {height: auto;line-height: 1;padding:0 7px;vertical-align: bottom;}     .sa-cron-num {text-align: center;margin-bottom: 15px;width: 100%;}     .sa-cron-num h2 {font-size: 12px;margin-bottom: 15px;font-weight: normal;}     .sa-cron-num h4 {display: block;height: 32px;line-height: 30px;width: 100%;font-size: 12px;padding:0 15px;background: var(--el-color-primary-light-9);border-radius:4px;}     .sa-cron:deep(.el-tabs__item.is-active) .sa-cron-num h4 {background: var(--el-color-primary);color: #fff;}
    [data-theme='dark'] .sa-cron-num h4 {background: var(--el-color-white);} </style>            

标签:arr,return,value,else,start,vue3cron,type,表达式
From: https://www.cnblogs.com/yebinghuai/p/18254459

相关文章

  • Lambda表达式:会这10招
    引言在Java8之前,Java的语法相对冗长,尤其是在处理集合操作和多线程编程时,常常需要大量的样板代码。自Java8引入Lambda表达式以来,Java编程变得更加简洁和高效,不仅减少了代码量,还提升了代码的可读性和可维护性。今天就来聊聊几种工作中很常用的Lambda表达式应用场景,走过路过别错......
  • @符号在DC等过滤器表达式中的用途
    在TCL脚本中,特别是在使用电子设计自动化(EDA)工具(如SynopsysDesignCompiler、CadenceInnovus等)时,@符号在过滤器表达式中有特定的用途。用途和解释@ref_name:@符号在过滤表达式中用于明确指示属性名称。属性是指对象的特定特征或信息(如ref_name)。*:通配符,用于匹配任何字符串。@......
  • python中常见re正则表达式(整数、小数、邮箱、号码、车牌、x开头y结尾)大合集(值得收
    目录专栏导读库的介绍库的安装1、匹配整数2、匹配某几位整数3、匹配小数4、匹配电话格式1:11位数字格式2:187-12341234或者187-1234-1234格式3:(123)456-7890,或者+86123-456-78905、匹配邮箱6、匹配车牌7、xx为开头yy为结尾9、匹配中文10、匹配非中文总结专栏导读......
  • 正则表达式合集
    //身份证正则表达式(15位) isIDCard1=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/; //身份证正则表达式(18位) isIDCard2=/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/; 地区、性别和身份证进行判断的正则表达式: <script> va......
  • Python爬虫之路(12)--re正则表达式
    正则表达式认识正则正则表达式,又称规则表达式,(RegularExpression,在代码中常简写为regex、regexp或RE),是一种文本模式,包括普通字符(例如,a到z之间的字母)和特殊字符(称为"元字符"),是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个语法规则的......
  • C#开发-集合使用和技巧(二)Lambda 表达式介绍和应用
    C#开发-集合使用和技巧Lambda表达式介绍和应用C#开发-集合使用和技巧介绍简单的示例:集合查询示例:1.基本语法从主体语句上区分:1.主体为单一表达式2.主体是代码块(多个表达式语句)从参数上区分1.带输入参数的Lambda表达式2.不带输入参数的Lambda表达式特殊用法:2.......
  • 代码随想录算法训练营第11、12天 | 逆波兰表达式、滑动窗口最大值、前 K 个高频元素
    逆波兰表达式题目https://leetcode.cn/problems/evaluate-reverse-polish-notation/description/逆波兰表达式代码随想录https://programmercarl.com/0150.逆波兰表达式求值.html#其他语言版本滑动窗口最大值https://leetcode.cn/problems/sliding-window-maximum/滑动窗口......
  • Python笔记 - 正则表达式
    正则表达式(RegularExpression,简称regex)是一种强大的工具,用于匹配字符串模式。在Python中,正则表达式通过re模块提供。本文将带你深入了解Python中的正则表达式,从基础概念到高级用法。1.什么是正则表达式?正则表达式是一种用来描述字符串模式的方法。它可以用来匹配、查找......
  • PHP正则表达式
    PHP正则表达式函数PHP正则表达式介绍正则表达式允许您搜索和替换字符串中的模式。安装PHP正则表达式函数是PHP核心的一部分。无需安装即可使用这些功能。运行时配置php.ini中的这些设置可用于限制计算正则表达式时使用的时间或资源量。名称默认值描述Changea......
  • 正则表达式
    正则表达式importre限定符(quantifier)a* a出现0次或者多次a+ a出现1次或者多次a? a出现0次或者一次a{6} a出现6次a{2,6}a出现2-6次a{2,} a出现两次以上或运算符(OROperator)(a|b) 匹配(ab)|(cd) 匹配ab或者cd字符类(CharacterClasses)[abc] 匹配a或者b......