提交 acb6cb08 编写于 作者: B baiy 提交者: ninecents

添加时间计算器 #16

上级 6c6122a6
......@@ -77,6 +77,10 @@ const routes = [
{
path: '/tool/unit',
component: r => require(['./views/tool/unit.vue'], r)
},
{
path: '/tool/time',
component: r => require(['./views/tool/time.vue'], r)
}
]
......
......@@ -8,7 +8,7 @@ export const BADGE_EXPIRY = 10
// 分类徽章
export const BADGE_CATEGORY = ['other']
// 工具徽章
export const BADGE_TOOL = ['unit']
export const BADGE_TOOL = ['time']
// 默认常用工具
export const DEFAULT_COMMON_TOOL = [
'hash', 'encrypt', 'base64', 'url', 'timestamp',
......@@ -43,6 +43,7 @@ const tool = [
{ 'name': 'crontab', 'title': 'crontab校验', cat: ['other'] },
{ 'name': 'websocket', 'title': 'websocket调试', cat: ['other'] },
{ 'name': 'unit', 'title': '单位换算', cat: ['other'] },
{ 'name': 'time', 'title': '时间计算器', cat: ['other'] },
]
// 徽章是否显示
......
<template>
<div>
<Tabs name="default">
<TabPane label="差值计算器" name="default">
<option-block>
<FormItem>
<DatePicker transfer v-model="current.poor.input1" :options="options" type="datetime"
format="yyyy-MM-dd HH:mm:ss"></DatePicker>
</FormItem>
<FormItem>
</FormItem>
<FormItem>
<DatePicker transfer v-model="current.poor.input2" :options="options" type="datetime"
format="yyyy-MM-dd HH:mm:ss"></DatePicker>
</FormItem>
<FormItem>
相差
</FormItem>
<FormItem>
<Input v-model="poor">
<Select transfer v-model="current.poor.unit" slot="append" style="width: 60px">
<Option v-for="v in poorUnit" :value="v.v" :v-key="v.v">{{v.n}}</Option>
</Select>
</Input>
</FormItem>
</option-block>
</TabPane>
</Tabs>
<Tabs name="default">
<TabPane label="时间操作" name="default">
<option-block>
<FormItem>
<DatePicker transfer v-model="current.duration.input" :options="options" type="datetime"
format="yyyy-MM-dd HH:mm:ss"></DatePicker>
</FormItem>
<FormItem>
<Select transfer v-model="current.duration.type" style="width: 60px">
<Option value="+">添加</Option>
<Option value="-">减少</Option>
</Select>
</FormItem>
<FormItem>
<Input v-model="current.duration.length" type="number" number>
<Select transfer v-model="current.duration.unit" slot="append" style="width: 60px">
<Option v-for="v in poorUnit" :value="v.v" :v-key="v.v">{{v.n}}</Option>
</Select>
</Input>
</FormItem>
<FormItem>
后, 为 <strong>{{duration}}</strong>
</FormItem>
</option-block>
</TabPane>
</Tabs>
</div>
</template>
<script>
import moment from 'moment'
export default {
created () {
this.current = Object.assign(this.current, this.$getToolData())
},
computed: {
poor () {
let a = moment(this.current.poor.input1)
let b = moment(this.current.poor.input2)
this.$saveToolData(this.current)
return b.diff(a, this.current.poor.unit)
},
duration () {
this.$saveToolData(this.current)
const type = this.current.duration.type === '+' ? 'add' : 'subtract'
return moment(this.current.duration.input)[type](this.current.duration.length, this.current.duration.unit).
format('YYYY-MM-DD HH:mm:ss')
},
},
data () {
return {
options: {
shortcuts: [
{
text: '当前时间',
value () {
return moment().toDate()
},
},
{
text: '当前日期',
value () {
return moment(moment().format('YYYY-MM-DD')).toDate()
},
},
{
text: '当月日期',
value () {
return moment(moment().format('YYYY-MM-01')).toDate()
},
},
{
text: '当年日期',
value () {
return moment(moment().format('YYYY-01-01')).toDate()
},
},
],
},
poorUnit: [
{ v: 'years', n: '' },
{ v: 'months', n: '' },
{ v: 'weeks', n: '' },
{ v: 'days', n: '' },
{ v: 'hours', n: '小时' },
{ v: 'minutes', n: '分钟' },
{ v: 'seconds', n: '' },
],
current: {
poor: {
input1: moment(moment().format('YYYY-MM-DD')).toDate(),
input2: moment(moment().format('YYYY-MM-DD')).add(1, 'd').toDate(),
unit: 'seconds',
},
duration: {
input: moment(moment().format('YYYY-MM-DD')).toDate(),
unit: 'days',
type: '+',
length: 1,
},
},
}
},
}
</script>
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册