0.6.1 • Published 5 years ago
vue-pikaday-directive v0.6.1
Vue-Pikaday
A simple yet flexible custom directive for using Pikaday in Vue.js (v2.x.x) apps.

Demo
Usage
- Install via npm: - npm install vue-pikaday-directive --save
- Register Vue-Pikaday as a directive in your Vue.js app: - // this is your main.js file import Vue from 'vue'; import V_Pikaday from 'vue-pikaday-directive'; const App = new Vue({ el: '#app', data: { startDate: '', endDate: '' }, directives: { 'pikaday': V_Pikaday } });
- Vue-Pikaday need an - <input>element to display date. Add- v-modeland- v-pikadaydirective to this- <input>.- // this is your index.html file ... <input id="this-is-start-date" type="text" v-model="startDate" v-pikaday> <input id="this-is-end-date" type="text" v-model="endDate" v-pikaday> ...- You may wonder why we need both - v-modeland- v-pikadayhere.- v-modelis for data binding.- v-pikadayis just for initializing the Pikaday instance. It DOES NOT do any data binding job.
- If you need to set some custom options for a specific Pikaday instance (eg. a different format of date), you can do it by binding an options object to - v-pikadaydirective:- // this is your index.html file ... <input id="this-is-start-date" type="text" v-model="startDate" v-pikaday> <input id="this-is-end-date" type="text" v-model="endDate" v-pikaday="endDatePikadayOptions"> ... // this is your main.js file ... const App = new Vue({ el: '#app', data: { startDate: '', endDate: '', endDatePikadayOptions: { format: 'D/M/YYYY', // you can put more pikaday options here, based on your needs // however `field` and `onSelect` option will be ignored // because they are being used by v-pikaday directive to initialize a Pikaday instance }, }, directives: { 'pikaday': V_Pikaday } });
- If you need to access a Pikaday instance, you can do it by: - // this is your main.js file ... mounted: function () { const startDateElement = document.querySelector('#this-is-start-date'); console.log(startDateElement.pikadayInstance); // you can access a Pikaday instance at the `mounted` stage of the parent VM // by accessing the `pikadayInstance` property of the element that v-pikaday directive is bind with } ...
License
MIT