vue js moment.js 过滤了双休日和法定节假日
源码:注!原创的!!!!
<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 过滤了双休日和法定节假日的更多相关文章
- Vue 入门指南 JS
Vue 入门指南 章节导航 英文:http://vuejs.org/guide/index.html 介绍 vue.js 是用来构建web应用接口的一个库 技术上,Vue.js 重点集中在MVVM模式 ...
- Vue过渡效果之JS过渡
前面的话 与CSS过渡不同,JS过渡主要通过事件进行触发.本文将详细介绍Vue过渡效果之JS过渡 事件钩子 JS过渡主要通过事件监听事件钩子来触发过渡,共包括如下的事件钩子 <transitio ...
- 使用 Vue 和 epub.js 制作电子书阅读器
ePub 简介 ePub 是一种电子书的标准格式,平时我看的电子书大部分是这种格式.在手机上我一般用"多看"阅读 ePub 电子书,在 Windows 上找不到用起来比较顺心的软件 ...
- socket应用(vue、node.js、M站)
socket应用(vue.node.js.M站) 前言:我们在做一些项目的时候需要做到实时变化, 比如我们有时候有需求会要求我们做一个类似于聊天室的页面 比如有些时候我们对某些东西进行点赞和刷票,需要 ...
- vue项目中主要文件的加载顺序(index.html、App.vue、main.js)
先后顺序: index.html > App.vue的export外的js代码 > main.js > App.vue的export里面的js代码 > Index.vue的ex ...
- 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 ...
- vue中引入js,然后new js里的方法
阿里云Web播放器Web端使用SDK说明:https://help.aliyun.com/document_detail/51991.html?spm=5176.11065259.1996646101 ...
- 最新的vue没有dev-server.js文件,如何进行后台数据模拟?
https://blog.csdn.net/qq_34645412/article/details/78833860 https://blog.csdn.net/qq_34645412/article ...
- vue中eslintrc.js配置最详细介绍
本文是对vue项目中自带文件eslintrc.js的内容解析, 介绍了各个eslint配置项的作用,以及为什么这样设置. 比较详细,看完能对eslint有较为全面的了解,基本解除对该文件的疑惑. /* ...
随机推荐
- 使用Masonry在UIScrollView内布局
理论分析 首先,我们知道Autolayout改变了传统的以frame为主的布局思想.它其实是一种相对布局,核心思想是视图与视图之间的位置关系.比如,我们可以根据矩形的起始横坐标.纵坐标.长和宽这四个变 ...
- C++实现成绩管理模拟系统
C++实现基本的成绩管理系统 需求: 1-学生姓名等基本字段 2-学生成绩字段 3-实现成绩修改和基本统计输出 #include<iostream> #include<windows ...
- python入门篇之介绍和流程控制(一)
Python入门 一.第一句python代码 很多语言的第一句python代码都是以“你好,世界”开始的,那么我们的python也是如此. 在 /home/dev/ 目录下创建 hello.py 文件 ...
- 用CSS3画出一个立方体---转
css3实践—创建3D立方体 要想实现3D的效果,其实非常简单,只需指定一个元素为容器并设置transform-style:preserve-3d,那么它的后代元素便会有3D效果.不过有很多需要注意的 ...
- codevs 2796 最小完全图
2796 最小完全图 http://codevs.cn/problem/2796/ 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description 若一个图的每一对不 ...
- 【BZOJ】3992: [SDOI2015]序列统计 NTT+生成函数
[题意]给定一个[0,m-1]范围内的数字集合S,从中选择n个数字(可重复)构成序列.给定x,求序列所有数字乘积%m后为x的序列方案数%1004535809.1<=n<=10^9,3< ...
- 【CodeForces】908 D. New Year and Arbitrary Arrangement
[题目]Good Bye 2017 D. New Year and Arbitrary Arrangement [题意]给定正整数k,pa,pb,初始有空字符串,每次有pa/(pa+pb)的可能在字符 ...
- 20155117王震宇 实验三 敏捷开发与XP实践 实验报告
实验内容 XP基础 XP核心实践 相关工具 实验要求 1.没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim编辑器> 课程 2.完成实验.撰写实验报告,实 ...
- 【洛谷 P1772】 [ZJOI2006]物流运输(Spfa,dp)
题目链接 \(g[i][j]\)表示不走在\(i\text{~}j\)时间段中会关闭的港口(哪怕只关\(1\)天)从\(1\)到\(m\)的最短路. \(f[i]\)表示前\(i\)天的最小花费.于是 ...
- Knockout双向绑定
knockout双工绑定基于 observe 模式,性能高.核心就是observable对象的定义.这个函数最后返回了一个也叫做 observable 的函数,也就是用户定义值的读写器(accesso ...