✨(component): 发布 1.2.11 版本
This commit is contained in:
parent
eb09c753a5
commit
3fc0c38362
@ -12,10 +12,10 @@ const getYears = () => {
|
|||||||
/**
|
/**
|
||||||
* 获取当前日期
|
* 获取当前日期
|
||||||
*/
|
*/
|
||||||
const getDate = (val='') => {
|
const getDate = (val = "") => {
|
||||||
if(val){
|
if (val) {
|
||||||
return new Date(val);
|
return new Date(val);
|
||||||
}else{
|
} else {
|
||||||
return new Date();
|
return new Date();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -23,24 +23,24 @@ const getDate = (val='') => {
|
|||||||
/**
|
/**
|
||||||
* 获取当前年份
|
* 获取当前年份
|
||||||
*/
|
*/
|
||||||
const getYear = (val='') => {
|
const getYear = (val = "") => {
|
||||||
return getDate(val).getFullYear();
|
return getDate(val).getFullYear();
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取当前月份
|
* 获取当前月份
|
||||||
*/
|
*/
|
||||||
const getMonth = (val='') => {
|
const getMonth = (val = "") => {
|
||||||
return getDate(val).getMonth();
|
return getDate(val).getMonth();
|
||||||
};
|
};
|
||||||
|
|
||||||
const getDay=(val='')=>{
|
const getDay = (val = "") => {
|
||||||
if(val){
|
if (val) {
|
||||||
return new Date(getDate(val).toDateString()).getTime();
|
return new Date(getDate(val).toDateString()).getTime();
|
||||||
}else{
|
} else {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取月份天数
|
* 获取月份天数
|
||||||
@ -52,4 +52,4 @@ const getDayLength = (year: number, month: number): number => {
|
|||||||
return new Date(year, month + 1, 0).getDate();
|
return new Date(year, month + 1, 0).getDate();
|
||||||
};
|
};
|
||||||
|
|
||||||
export { getDayLength, getYears, getDate, getMonth, getYear,getDay };
|
export { getDayLength, getYears, getDate, getMonth, getYear, getDay };
|
||||||
|
@ -84,7 +84,10 @@
|
|||||||
<div class="layui-laydate-footer">
|
<div class="layui-laydate-footer">
|
||||||
<span
|
<span
|
||||||
v-if="type === 'datetime'"
|
v-if="type === 'datetime'"
|
||||||
@click="showPane = 'time';scrollToCurrentTime()"
|
@click="
|
||||||
|
showPane = 'time';
|
||||||
|
scrollToCurrentTime();
|
||||||
|
"
|
||||||
class="laydate-btns-time"
|
class="laydate-btns-time"
|
||||||
>选择时间</span
|
>选择时间</span
|
||||||
>
|
>
|
||||||
@ -218,8 +221,16 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="layui-laydate-content" style="height: 210px">
|
<div class="layui-laydate-content" style="height: 210px">
|
||||||
<ul class="layui-laydate-list laydate-time-list" ref="timePanelRef">
|
<ul
|
||||||
<li class="num-list" v-for="item in els" :key="item.type" :data-type="item.type">
|
class="layui-laydate-list laydate-time-list"
|
||||||
|
ref="timePanelRef"
|
||||||
|
>
|
||||||
|
<li
|
||||||
|
class="num-list"
|
||||||
|
v-for="item in els"
|
||||||
|
:key="item.type"
|
||||||
|
:data-type="item.type"
|
||||||
|
>
|
||||||
<ol class="scroll" @click="choseTime">
|
<ol class="scroll" @click="choseTime">
|
||||||
<li
|
<li
|
||||||
v-for="(it, index) in item.count"
|
v-for="(it, index) in item.count"
|
||||||
@ -278,8 +289,16 @@ import dayjs from "dayjs";
|
|||||||
import { LayIcon } from "@layui/icons-vue";
|
import { LayIcon } from "@layui/icons-vue";
|
||||||
import LayInput from "../input/index.vue";
|
import LayInput from "../input/index.vue";
|
||||||
import LayDropdown from "../dropdown/index.vue";
|
import LayDropdown from "../dropdown/index.vue";
|
||||||
import { getDayLength, getYears, getMonth, getYear,getDay } from "./day";
|
import { getDayLength, getYears, getMonth, getYear, getDay } from "./day";
|
||||||
import { ref, watch, computed, defineProps, defineEmits, onMounted, nextTick } from "vue";
|
import {
|
||||||
|
ref,
|
||||||
|
watch,
|
||||||
|
computed,
|
||||||
|
defineProps,
|
||||||
|
defineEmits,
|
||||||
|
onMounted,
|
||||||
|
nextTick,
|
||||||
|
} from "vue";
|
||||||
import { anyTypeAnnotation } from "@babel/types";
|
import { anyTypeAnnotation } from "@babel/types";
|
||||||
|
|
||||||
export interface LayDatePickerProps {
|
export interface LayDatePickerProps {
|
||||||
@ -339,7 +358,7 @@ const yearList = ref<number[]>(getYears());
|
|||||||
const dateList = ref<any[]>([]);
|
const dateList = ref<any[]>([]);
|
||||||
const showPane = ref("date");
|
const showPane = ref("date");
|
||||||
|
|
||||||
const yearmonthScrollRef=ref()
|
const yearmonthScrollRef = ref();
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
() => props.type,
|
() => props.type,
|
||||||
@ -356,9 +375,10 @@ onMounted(() => {
|
|||||||
clear();
|
clear();
|
||||||
}, 0);
|
}, 0);
|
||||||
}
|
}
|
||||||
let modelValue=props.modelValue;
|
let modelValue = props.modelValue;
|
||||||
if(modelValue.length===8){ //dayjs 解析时间容错
|
if (modelValue.length === 8) {
|
||||||
modelValue='1970-01-01 '+modelValue;
|
//dayjs 解析时间容错
|
||||||
|
modelValue = "1970-01-01 " + modelValue;
|
||||||
}
|
}
|
||||||
hms.value.hh = dayjs(modelValue).hour();
|
hms.value.hh = dayjs(modelValue).hour();
|
||||||
hms.value.mm = dayjs(modelValue).minute();
|
hms.value.mm = dayjs(modelValue).minute();
|
||||||
@ -562,45 +582,50 @@ const choseTime = (e: any) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const openDropDown=()=>{
|
const openDropDown = () => {
|
||||||
nextTick(()=>{
|
nextTick(() => {
|
||||||
if(showPane.value=='year'||showPane.value=='yearmonth'){
|
if (showPane.value == "year" || showPane.value == "yearmonth") {
|
||||||
let scrollTop=0;
|
let scrollTop = 0;
|
||||||
for (const child of yearmonthScrollRef.value.firstElementChild.childNodes) {
|
for (const child of yearmonthScrollRef.value.firstElementChild
|
||||||
if(child.classList&&child.classList.contains('layui-this')){
|
.childNodes) {
|
||||||
scrollTop=child.offsetTop-(yearmonthScrollRef.value.offsetHeight-child.offsetHeight)/2;
|
if (child.classList && child.classList.contains("layui-this")) {
|
||||||
|
scrollTop =
|
||||||
|
child.offsetTop -
|
||||||
|
(yearmonthScrollRef.value.offsetHeight - child.offsetHeight) / 2;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
yearmonthScrollRef.value.scrollTo(0,scrollTop)
|
yearmonthScrollRef.value.scrollTo(0, scrollTop);
|
||||||
}else if(showPane.value=='time'){
|
} else if (showPane.value == "time") {
|
||||||
scrollToCurrentTime()
|
scrollToCurrentTime();
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
}
|
};
|
||||||
|
|
||||||
//时间定位
|
//时间定位
|
||||||
const timePanelRef=ref()
|
const timePanelRef = ref();
|
||||||
const scrollToCurrentTime = () => {
|
const scrollToCurrentTime = () => {
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
timePanelRef.value.childNodes.forEach((element: HTMLElement) => {
|
timePanelRef.value.childNodes.forEach((element: HTMLElement) => {
|
||||||
if (element.nodeName === 'LI') {
|
if (element.nodeName === "LI") {
|
||||||
let scrollTop = 0;
|
let scrollTop = 0;
|
||||||
let parentDom = element.firstElementChild as HTMLElement;
|
let parentDom = element.firstElementChild as HTMLElement;
|
||||||
let childList = parentDom.childNodes;
|
let childList = parentDom.childNodes;
|
||||||
for (let index = 0; index < childList.length; index++) {
|
for (let index = 0; index < childList.length; index++) {
|
||||||
const child = childList[index] as HTMLElement;
|
const child = childList[index] as HTMLElement;
|
||||||
if (child.nodeName !== 'LI') {
|
if (child.nodeName !== "LI") {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (child.classList && child.classList.contains('layui-this')) {
|
if (child.classList && child.classList.contains("layui-this")) {
|
||||||
scrollTop = child.offsetTop - (parentDom.offsetHeight - child.offsetHeight) / 2;
|
scrollTop =
|
||||||
parentDom.scrollTo(0, scrollTop)
|
child.offsetTop -
|
||||||
|
(parentDom.offsetHeight - child.offsetHeight) / 2;
|
||||||
|
parentDom.scrollTo(0, scrollTop);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
})
|
});
|
||||||
}
|
};
|
||||||
</script>
|
</script>
|
||||||
|
Loading…
Reference in New Issue
Block a user