废话不多说直接上代码,拷贝代码保存为 html 文件,用浏览器打开就可以看到效果。
在线查看效果:
https://run.iviewui.com/PmGsUW3P
<!DOCTYPE html>
<meta charset="utf-8" />
<title>Vue.js中使用iView日期选择器并设置开始时间结束时间校验</title>
<!-- import Vue.js -->
<script src="https://vuejs.org/js/vue.min.js"></script>
<!-- import stylesheet -->
<link rel="stylesheet" href="https://unpkg.com/iview/dist/styles/iview.css">
<!-- import iView -->
<script src="https://unpkg.com/iview/dist/iview.min.js"></script>
</head>
<div id="app">
<template>
<Col span="12"> 开始时间:
<date-picker type="datetime" v-model="startTime" placeholder="请选择开始时间" :options="startTimeOption" @on-change="onStartTimeChange"></date-picker>
<Col span="12"> 结束时间:
<date-picker type="datetime" v-model="endTime" placeholder="请选择结束时间" :options="endTimeOption" @on-change="onEndTimeChange"></date-picker>
</template>
<script>
new Vue({
el: '#app',
data() {
return {
startTime: '',
endTime: '',
startTimeOption: {},
endTimeOption: {}
mounted() {
this.startTime = '2018-08-08 00:00:00'
this.endTime = '2018-08-11 23:59:59'
this.onStartTimeChange(this.startTime)
this.onEndTimeChange(this.endTime)
methods: {
* 开始时间发生变化时触发,设置结束时间不可选择的日期
* 结束时间应大于等于开始时间,且小于等于当前时间
* @param {string} startTime 格式化后的日期
* @param {string} type 当前的日期类型
onStartTimeChange(startTime, type) {
this.endTimeOption = {
disabledDate(endTime) {
return endTime < new Date(startTime) || endTime > Date.now()
* 结束时间发生变化时触发,设置开始时间不可选择的日期
* 开始时间小于等于结束时间,且小于等于当前时间
* @param {string} date 格式化后的日期
* @param {string} type 当前的日期类型
onEndTimeChange(endTime, type) {
this.startTimeOption = {
disabledDate(startTime) {
return startTime > new Date(endTime) || startTime > Date.now()
</script>
</body>
</html>
废话不多说直接上代码,拷贝代码保存为 html 文件,用浏览器打开就可以看到效果。在线查看效果:https://run.iviewui.com/PmGsUW3P&lt;!DOCTYPE html&gt;&lt;html&gt;&lt;head&gt; &lt;meta charset="utf-8" /&gt; &lt;title&gt;Vue.js中使用iView日期选择器并...
<view>搜索日期:</view>
{{defaultStartTime}}<image @click="selStart" class="ssel-icon" src="/static/images/ssel.png"></image>
<u-picker
mode="time"
:defaultTime="defaultStartTime"
uView中picker的mode=time时默认样式
由于项目需求,需要把时间的选择范围限制在当前日期的10时以后,不能选择以前的日期,也就是说今天是2021.9.2,不能选择2021.9.1及以前的日期,查找文档后没找到解决方法,只能修改其源码
2.解决方法
找到picker的源码位置==>uview-ui==>components==>u-picker==>u-picker.vue
来到429行
<FormItem label="选择完成时间: ">
<DatePicker type="datetime" :value="form.time" format="yyyy-MM-dd HH:mm" @on-change="_changeDate"
style="width: 200px">&
<DatePicker v-model="formBorrower.termValidity"
@on-change="formBorrower.termValidity=$event" format="yyyy/MM/dd"
style="width: 100%" type="date" placeholder="选择日期"><...
最近在用iview 做项目,这个时间的验证这一块卡住了,发现大部分的都是关于date和datetime 的验证问题,下面把我的关于datetimerange 的验证发出来供大家参考<Form-item label="投放时间" prop="startEndTime">
<DatePicker :value="formItem.startEndTime" @on-chang...
Vue xlsx.js 是一种前端库,它可以使您使用JavaScript读取、解析和导出电子表格文件,如Microsoft Excel。当您在 Vue xlsx.js 中设置日期列时,可以选择将其格式化为时间格式。这意味着,当您在电子表格中输入日期时,该日期将被自动转换为一种可读的时间格式。使用该库,您可以根据自己的需求格式化日期列,如将其转换为年月日、月日年、小时分钟等等。此外,Vue xlsx.js 不仅支持日期格式化,还可以支持各种其他数据类型的格式化,如数字、货币、百分比等等。总的来说,Vue xlsx.js 提供了丰富的格式化选项,使您能够轻松地将电子表格文件转换为可视化和易于理解的格式。