一、通过 remove 方法
<!DOCTYPE html>
<html>
<head>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.3/jquery.min.js"></script>
<script src="https://www.layuicdn.com/layui/layui.js"></script>
<link rel="stylesheet" type="text/css" href="https://www.layuicdn.com/layui/css/layui.css" />
<style>
#start_date_icon,#end_date_icon{
position: absolute;
right: 10px;
top: 50%;
margin-top: -15px;
cursor: pointer;
font-size: 30px;
}
</style>
</head>
<body>
<div>
<div class="layui-input-inline" id="myd1">
<input type="datetime" id="start_date" name="start_date" lay-verify='date' class="layui-input"/>
<i class="layui-icon layui-icon-date" id="start_date_icon"></i>
</div>
<div class="layui-input-inline" id="myd2">
<input type="datetime" id="end_date" name="end_date" lay-verify='date' class="layui-input"/>
<i class="layui-icon layui-icon-date" id="end_date_icon"></i>
</div>
</div>
<script type="text/javascript">
layui.use(['laydate'], function() {
var laydate = layui.laydate
var removeStart = function(value,date){
$("#start_date").remove();
$("#myd1").append('<input type="datetime" id="start_date" name="start_date" lay-verify="date" class="layui-input"/>');
var limitValue = value.replace('.', '-').replace('.', '-');
laydate.render({
elem: '#start_date',
eventElem: '#start_date_icon',
trigger: 'click',
format: 'yyyy.MM.dd',
max:limitValue,
})
}
var removeEnd = function(fuck,date){
console.log('fuck',fuck)
$("#end_date").remove();
$("#myd2").append('<input type="datetime" id="end_date" name="end_date" lay-verify="date" class="layui-input"/>');
var limitValue = fuck.replace('.', '-').replace('.', '-');
laydate.render({
elem: '#end_date',
format: 'yyyy.MM.dd',
eventElem: '#end_date_icon',
trigger: 'click',
min:limitValue,
})
}
laydate.render({
elem: '#start_date',
eventElem: '#start_date_icon',
trigger: 'click',
type:'date',
value:'2023.1.1',
format: 'yyyy.MM.dd',
done:removeEnd
});
laydate.render({
elem: '#end_date',
eventElem: '#end_date_icon',
type:'date',
value:'2023.2.1',
format: 'yyyy.MM.dd',
trigger: 'click',
done:removeStart
})
});
</script>
</body>
</html>
二、通过 config 方法
<!DOCTYPE html>
<html>
<head>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.3/jquery.min.js"></script>
<script src="https://www.layuicdn.com/layui/layui.js"></script>
<link rel="stylesheet" type="text/css" href="https://www.layuicdn.com/layui/css/layui.css" />
<style>
#start_date_icon,#end_date_icon{
position: absolute;
right: 10px;
top: 50%;
margin-top: -14px;
cursor: pointer;
font-size: 30px;
}
</style>
</head>
<body>
<div>
<div class="layui-input-inline" id="myd1">
<input type="datetime" id="start_date" name="start_date" lay-verify='date' class="layui-input"/>
<i class="layui-icon layui-icon-date" id="start_date_icon"></i>
</div>
<div class="layui-input-inline" id="myd2">
<input type="datetime" id="end_date" name="end_date" lay-verify='date' class="layui-input"/>
<i class="layui-icon layui-icon-date" id="end_date_icon"></i>
</div>
</div>
<script type="text/javascript">
layui.use(['laydate'], function() {
var laydate = layui.laydate
var start = laydate.render({
elem: '#start_date',
eventElem: '#start_date_icon',
type:'date',
format: 'yyyy.MM.dd',
value:'2023.1.1',
min:"2013-08-18",
max:"2099-06-16",
trigger: 'click',
done: function (value, dates) {
end.config.min ={
year:dates.year,
month:dates.month-1,
date: dates.date,
hours: 0,
minutes: 0,
seconds : 0
};
}
});
var end = laydate.render({
elem: '#end_date',
eventElem: '#end_date_icon',
type:'date',
format: 'yyyy.MM.dd',
value:'2023.2.1',
min:"2013-08-18",
max:"2099-06-16",
trigger: 'click',
done: function (value, dates) {
start.config.max ={
year:dates.year,
month:dates.month-1,
date: dates.date,
hours: 0,
minutes: 0,
seconds : 0
};
}
})
});
</script>
</body>
</html>