源码:注!原创的!!!!

<template>
<div id="DATE">
<ul class="dateForm" @change="VpushDateTime((ymd+hour+minute))">
<!-- 年月日 -->
<li class="ymd">
<div class="postion input">
<label @click.stop.prevent="selectState=true"><input type="text" v-model="ymd"><!--
--><i class="glyphicon glyphicon-triangle-bottom"></i>
</label>
</div>
<!-- 下拉列表年月日 -->
<select v-if="selectState" v-model="ymd" @click.stop="VgetSelect('ymdSelect',$event)" class="postion list select" id="ymdSelect" size="4">
<option v-for="itme in ymdList" v-text="itme" v-bind:value="itme"></option>
</select>
</li>
<!-- 小时 -->
<li class="hour">
<div class="postion input">
<label @click.stop="selectState=true"><input type="text" v-model="hour"><!--
--><i class="glyphicon glyphicon-triangle-bottom"></i>
</label>
</div>
<!-- 下拉列表小时 -->
<select v-if="selectState" v-model="hour" @click.stop="VgetSelect('hourSelect',$event)" class="postion list select" id="hourSelect" size="4">
<option v-for="(itme,i) in hourList" v-text="itme" v-bind:value="itme" ></option>
</select>
</li>
<!-- 分钟 -->
<li class="minute">
<div class="postion input">
<label @click.stop="selectState=true"><input type="text" v-model="minute"><!--
--><i class="glyphicon glyphicon-triangle-bottom"></i>
</label>
</div>
<!-- 下拉列表分钟 -->
<select v-if="selectState" v-model="minute" @click.stop="VgetSelect('minuteSelect',$event)" class="postion list select" id="minuteSelect" size="4">
<option v-for="itme in minuteList" v-text="itme" v-bind:value="itme"></option>
</select>
</li>
</ul>
<button @click="p=23,ps=!ps">change</button>
<p v-if="ps">{{p}}</p>
</div>
</template>
<script>
import moment from "moment";
//设置时间核心插件语言
moment.locale("zh-cn");
//字典=》全国放假日[因为不知道明年放假是如何定的,所以只写死今年]
const wordBookDate= ["2018年06月16日","2018年06月17日","2018年06月18日","2018年09月22日","2018年09月23日","2018年09月24日","2018年10月01日","2018年10月02日","2018年10月03日","2018年10月04日","2018年10月05日","2018年10月06日","2018年10月07日"]
;
export default {
props:{
init:''
},
data() {
return {
p:'12',
ps:false,
//输入框
//年月日
ymd: '',
//小时
hour: '',//moment().format('HH')+'时'
//分钟
minute: moment().format('mm')+'分'
//下拉框状态
,selectState:false
};
},
methods: {
//向父组件传值
VpushDateTime(data) {
const _this = this;
// _this.$emit("getDateTime", _this.ymd);
_this.$emit("getDateTime", data);
},
//下拉列表选择
VgetSelect(selectName,e){
const _this=this;
const oSelec=document.querySelector('#'+selectName); if(selectName.startsWith('ymd')){
//console.log('年月日');
//_this.ymd=(e.target).innerText;
}else if(selectName.startsWith('hour')) {
//console.log('小时的'); }else if(selectName.startsWith('minute')){
//console.log('分钟的'); }
/*oSelec.addEventListener("click",function(e){
console.log(selectName)
if(selectName.startsWith('ymd')){
console.log('年月日');
}else if(selectName.startsWith('hour')) {
console.log('小时的');
}else if(selectName.startsWith('hour')){
console.log('分钟的');
}
//_this.ymd=(e.target).innerText;
_this.ymd=(e.target).innerText;
//_this.VpushDateTime(_this.ymd);
},false)*/
},
//检测最终值是否正确
Vcheck(date){
const _this=this;
_this.VpushDateTime(date)
}, },
computed: {
/* year-month-day
hour
Minute */
//年月日
ymdList:()=>{
/*const _this=this;*/
let arr=[];
const month= wordBookDate[(moment().month()+2).toString()];
//取60天区间
for(let i=0;i<60;i++){
let ymd=moment().add(i,'day').format('L');
let day=moment(ymd).day();
//过滤周六日
if(!(day==0||day==6)){
ymd=ymd .replace(/[/]/, "年")
.replace(/[/]/, "月") + "日";
arr.push(ymd)
}
//过滤周六日完毕
}
//取60天区间完毕
//过滤法定节日
if(month.length!=0){
//传统写法
for(let i=0;i<arr.length;i++){
for(let m=0;m<=month.length;m++){
if(arr[i]==month[m]){
//改变原数组
arr.splice(i,1);
}
}
}
}
//过滤法定节日完毕
return arr;
},
//时
hourList:()=>{
return ['09时','10时','11时','13时','14时'];
},
//分
minuteList:()=>{
return ['00分','01分','02分','03分','04分','05分','06分','07分','08分','09分',
'10分','11分','12分','13分','14分','15分','16分','17分','18分','19分',
'20分','21分','22分','23分','24分','25分','26分','27分','28分','29分',
'30分','31分','32分','33分','34分','35分','36分','37分','38分','39分',
'40分','41分','42分','43分','44分','45分','46分','47分','48分','49分',
'50分','51分','52分','53分','54分','55分','56分','57分','58分','59分']
}
},
mounted() {
const _this = this;
//当鼠标点击旁边隐藏下拉框
document.documentElement.addEventListener('click',function (e) {
_this.selectState=false;
});
//console.clear();
//console.log(_this.init.type);
moment().hour() >= 15 ? _this.ymdList.splice(0,1) : '';
_this.ymd=_this.ymdList[0];//年月日输入赋值,默认第一个
_this.hour=_this.hourList[0];//小时,默认第一个
console.log(_this.hourList[0]);
_this.VpushDateTime((_this.ymd+_this.hour+_this.minute));
},
};
</script>
<style lang="scss" scoped>
/* 整体样式 */
.dateForm{
list-style: none;
padding: 0;margin:0;
&>li{
display: inline-block;
position: relative;
}
.postion{
position: absolute;
top:0;left: 0;
}
.postion.input{
z-index: 2;
background:#fff;
}
.postion.list{
padding: 0;
box-sizing: border-box;
width: 100%;
top:28px;
}
}
/* 输入框样式 */
label {
display: inline-block;
height: 26px;
line-height: 26px;
border: 1px solid #ddd;
padding: 0;
margin: 0;
overflow: hidden;
input {
padding: 0;
margin: 0;
outline: none;
border: none;
box-sizing: border-box;
padding-left: 3px;
}
i {
border-left: 1px solid #ddd;
display: inline-block;
line-height: 26px;
vertical-align: bottom;
text-align: center;
cursor: pointer;
font-size: 14px;
color: #6d6d6d;
}
}
.ymd {
width: 145px;
.postion.input{
width: 145px;
label{
width: 145px;
}
}
input {
width: 122px;
}
i {
padding-left: 3px;
}
}
.hour,
.minute {
width: 60px;
.postion.input{
width: 60px;
label{
width: 60px;
}
}
input {
width: 36px;
}
i {
width: 18px;
}
}
/* 下拉列表样式 */
.select{
background: #fff;
outline: none;
margin: 0;
padding:0;
option{
height: 28px;
line-height: 28px;
padding-top: 5px;
padding-left: 5px;
cursor: pointer;
}
option:hover,option:focus,option:active{
background: #1883D7;
color:#fff;
}
}
.select::-webkit-scrollbar{
width:2px;
background: #6d6d6d;
}
</style>

  

vue js moment.js 过滤了双休日和法定节假日的更多相关文章

  1. Vue 入门指南 JS

    Vue 入门指南 章节导航 英文:http://vuejs.org/guide/index.html 介绍 vue.js 是用来构建web应用接口的一个库 技术上,Vue.js 重点集中在MVVM模式 ...

  2. Vue过渡效果之JS过渡

    前面的话 与CSS过渡不同,JS过渡主要通过事件进行触发.本文将详细介绍Vue过渡效果之JS过渡 事件钩子 JS过渡主要通过事件监听事件钩子来触发过渡,共包括如下的事件钩子 <transitio ...

  3. 使用 Vue 和 epub.js 制作电子书阅读器

    ePub 简介 ePub 是一种电子书的标准格式,平时我看的电子书大部分是这种格式.在手机上我一般用"多看"阅读 ePub 电子书,在 Windows 上找不到用起来比较顺心的软件 ...

  4. socket应用(vue、node.js、M站)

    socket应用(vue.node.js.M站) 前言:我们在做一些项目的时候需要做到实时变化, 比如我们有时候有需求会要求我们做一个类似于聊天室的页面 比如有些时候我们对某些东西进行点赞和刷票,需要 ...

  5. vue项目中主要文件的加载顺序(index.html、App.vue、main.js)

    先后顺序: index.html > App.vue的export外的js代码 > main.js > App.vue的export里面的js代码 > Index.vue的ex ...

  6. vue.runtime.esm.js:593 [Vue warn]: Invalid prop: custom validator check failed for prop "value".报错解决

    在uni中使用 picker组件,一直报错 vue.runtime.esm.js:593 [Vue warn]: Invalid prop: custom validator check failed ...

  7. vue中引入js,然后new js里的方法

    阿里云Web播放器Web端使用SDK说明:https://help.aliyun.com/document_detail/51991.html?spm=5176.11065259.1996646101 ...

  8. 最新的vue没有dev-server.js文件,如何进行后台数据模拟?

    https://blog.csdn.net/qq_34645412/article/details/78833860 https://blog.csdn.net/qq_34645412/article ...

  9. vue中eslintrc.js配置最详细介绍

    本文是对vue项目中自带文件eslintrc.js的内容解析, 介绍了各个eslint配置项的作用,以及为什么这样设置. 比较详细,看完能对eslint有较为全面的了解,基本解除对该文件的疑惑. /* ...

随机推荐

  1. mac 的全文搜索

    grep -Rni "view.proptypes.style" *  需要切换到要搜索的目录在运行

  2. laravel query builder/ Eloquent builder 添加自定义方法

    上次干这事已经是一年前了,之前的做法特别的繁琐.冗余,具体就是创建一个自定义 Builder 类,继承自 Query\Builder,然后覆盖 Connection 里面获取 Builder 的方法, ...

  3. jsp 的 3 个编译指令

    JSP 的编译指令是通知 JSP 引擎的消息,它不直接生成输出. 常见的编译指令有如下三个: 1.page:该指令是针对当前页面的指令 2.include:用于指定包含另一个页面 3.taglib:用 ...

  4. 5、Linux操作系统介绍

    1操作系统的作用·是现代计算机系统中最基本和最重要的系统软件·是配置在计算机硬件上的第一层软件,是对硬件系统的首次扩展·主要作用是管理好硬件设备,并为用户和应用程序提供一个简单的接口,以便于使用·而其 ...

  5. 好久没写了,SQLSERVER服务丢失后怎么办

    服务器突然中了病毒,查杀后,结果两个服务也丢了, 从其他机器上COPY了两个EXE过来,编写这两个服务就搞定了,不用重装MSSQL2005了 sc create MSSQLSERVER binpath ...

  6. 福建工程学院寒假作业第一周G题

    涨姿势题1 TimeLimit:1000MS  MemoryLimit:128000KB 64-bit integer IO format:%lld   涨姿势题就是所谓的优化题,在组队赛中,队伍发现 ...

  7. Mysql储存过程5: while

    循环结构 while create procedure name() begin while 条件 do SQL语句 end while; end$ create procedure aa6() be ...

  8. 转:字符集和字符编码(Charset & Encoding)

    转自:http://www.cnblogs.com/skynet/archive/2011/05/03/2035105.html ——每个软件开发人员应该无条件掌握的知识! ——Unicode伟大的创 ...

  9. java线上应用故障排查之二:高内存占用【转】

    前一篇介绍了线上应用故障排查之一:高CPU占用,这篇主要分析高内存占用故障的排查. 搞Java开发的,经常会碰到下面两种异常: 1.java.lang.OutOfMemoryError: PermGe ...

  10. elk系列2之multiline模块的使用【转】

    preface 上回说道了elk的安装以及kibana的简单搜索语法,还有logstash的input,output的语法,但是我们在使用中发现了一个问题,我们知道,elk是每一行为一个事件,像Jav ...