Vue Mint-UI Datetime picker 中的起始时间和结束时间

Vue Mint-UI Datetime picker 中的起始时间和结束时间

Datetime picker 效果

1、官网效果

img

官网上给出了一些 API 文档,但是 Mint UI 的文档 写的真心不怎么样,这里分享一下 Mint UI 的源码,这里是 Datetime picker 的源码。

img

既然是选择出生日期,那可选日期当然需要做一些限制,粗略地处理为 1900-01-01 ~ 当前时间。注意到文档中的 startDate 和 endDate 可以控制起止时间,但是没有说明如何使用,源码中也没有例子。如果我们直接设置时间格式的字符串,如 startDate: "1901-01-01",这样写是会报错的。

img

根据上图可以看出传入 startDate 的值必须是 Date 类型,所以按下面的写法就可以了:

startDate: new Date("1901-01-01"),endDate: new Date()

img

<!--出生日期的picker--><mt-datetime-picker ref="birthdayPicker" type="date" v-model="user.usbirthday" year-format="{value} 年" month-format="{value} 月" date-format="{value} 日"             :startDate="startDate" :endDate="endDate" @confirm="handleChange"></mt-datetime-picker>

v-model="user.usbirthday"中的 user.usbirthday 可以设置成 this.user.usbirthday = 1995-01-01

img

// 打开date-pickeropenPicker(picker) {    this.$refs[picker].open();},// picker选择的日期改变handleChange(value) {    this.birthday = moment(value).format('YYYY-MM-DD');}
2、实现效果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2k2XFG7r-1593533527832)(http://media.liuxianyu.cn/vue-mintui-datetime-picker-2.gif)]

3、引入 Moment.js

随笔中的代码涉及了 Moment.js,这是一个用来格式化时间的 js 插件,比如下图的时间不便于前端使用,则可以通过 Moment.js 将其转化为 2018-11-19 等格式的时间。

img

安装方式: npm i moment

中文官网: http://momentjs.cn/

Github: https://github.com/moment/moment/

然后在 main.js 中添加下面两行代码来引入 Moment.js:

 // 引入moment用来格式化时间
import moment from "moment";
Vue.prototype.$moment = moment;

常用格式化:

let date = moment(new Date("1901-01-01")).format("YYYY-MM-DD HH:mm:ss");let now = moment(new Date()).format("YYYY-MM-DD HH:mm:ss");console.log(date);        // 1901-01-01 08:00:00console.log(now);         // 2018-11-19 19:20:06

以上

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值