1.1.9 • Published 5 years ago

zeero-calendar v1.1.9

Weekly downloads
4
License
ISC
Repository
github
Last release
5 years ago

安装:

  npm install zeero-calendar --save 

全局引用或在使用页面引入

  import ZeeroCalendar from 'zeero-calendar' 

在页面注册使用

  export default {
    components: { 
      ZeeroCalendar 
    }, 
    data () { 
      return { 
        scope:'',
        evocation:false 
      }
    } 
  } 

这样可以在页面中添加HTML 标签

  <ZeeroCalendar :zcbox='ptt' :inputname="selectinput" @zeerodate="setdata"> 

事件说明:

zcbox 这个需要传送需要使用日期的输入框的OBJECT信息回到插件中

如何获取输入框input的object?

在需要获得日期的输入框 增加 $ref 并添加输入框的点击 或者焦点事件(推荐点击)

例如:@click="demo()" 具体看下面的两个示例

示例:

1、(外部点击打开) <div class="dateicon" @click="demo()">

2、输入框点击打开 <input type="text" ref="inputa" v-model="scope" @click="demo()"/>

在methods: 中定义点击函数事件

demo(){

  //使用时先获取需要插入的输入框的v-model名称

  this.selectinput='scope'
  
  //根据$ref来定位显示的位置

  let  st=new  Object(JSON.parse(JSON.stringify(this.$refs.inputa.getBoundingClientRect())))

  this.ptt=st//把定位传给子组件

  this.evocation=true//显示出来 然后执行自定义点击事件setdata 通过判断nm来识别val 插入的输入框是哪个

} 

插件上的自定义函数事件会给与你需要的日期

继续在函数里定义一个 setdata(val,nm) 带参函数事件

setdata(val,nm){
	if(nm=='scope'){
		this.scope=val
	}
	this.evocation=false
}

val 是日期; nm 是需要给那个input 的 v-model 如果有多个输入框使用在此判断就好了,可以使用switch case……

完整的demo

<template>
  <div class="hello">
    <zeeroCalendar v-if="evocation" :zcbox='ptt' :inputname="selectinput" @zeerodate="setdata"></zeeroCalendar>
    <input type="text" ref="inputa" v-model="scope" @click="demo()"/>
  </div>
</template>

<script>
import zeeroCalendar from 'zeero-calendar'
export default {
  components: { 
    zeeroCalendar 
  },
  data () {
    return {
      scope:'',
      evocation:false,
      ptt:Object(),
      selectinput:""
    }
  },
  methods: {
    demo(){
      this.selectinput='scope'
      let  st=new  Object(JSON.parse(JSON.stringify(this.$refs.inputa.getBoundingClientRect())))
      this.ptt=st
      this.evocation=true
    },
    setdata(val,nm){
      if(nm=='scope'){
          this.scope=val
      }
      this.evocation=false
    }
  }
}
</script>
<style scoped>
</style>
1.1.9

5 years ago

1.1.8

5 years ago

1.1.7

5 years ago

1.1.6

5 years ago

1.1.5

5 years ago

1.1.3

5 years ago

1.1.2

5 years ago

1.1.0

5 years ago

1.0.9

5 years ago

1.0.8

5 years ago

1.0.7

5 years ago

1.0.6

5 years ago

1.0.5

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.0

5 years ago