A Vue directive for using element queries to build responsive components.
npm install vue-element-queries_This package is only a prototype for now. Let me know if you find this useful and I will continue to work on it._
Have you ever wanted to build a vue component that was responsive to the containing element, rather than the window size? Now you can :)
I built this directive from looking at the amazing package css-element-queries. I ran into some performance issues using css-element-queries with dynamic elements coming in and out of vue, so I rewrote some of the core implementation with Vue in mind.
I plan to replace ResizeSensor at some point, and there may be many, many bugs as it's not nearly as flexible as css-media-queries. Send me feedback please!
How To Use VueElementQuery
Take the package for a spin using the latest vue-cli vue serve ./example
Install the plugin as you normally would with Vue.use(VueElementQuery)
``
import VueElementQuery from 'vue-element-queries'
Vue.use(VueElementQuery)
`
This makes the directive v-query available to you. Add this directive to the containing element you want your components to respond to.
``
This will watch the container and apply tags to the element for min-width and max-width. You can then target these tags in your css to make your components responsive.
``
_Note: stylesheets must be scoped for the current implementation of vue-element-queries._
Take a look at Example.vue in the example directory. You can use the sass mixins provided to clean up your css quite a bit.
```