| 1234567891011121314151617181920212223242526272829303132333435363738394041 |
- // register the grid component
- Vue.component('demo-grid', {
- template: '#grid-template',
- replace: true,
- props: {
- data: Array,
- columns: Array,
- filterKey: String
- },
- data: function () {
- var sortOrders = {}
- this.columns.forEach(function (key) {
- sortOrders[key] = 1
- })
- return {
- sortKey: '',
- sortOrders: sortOrders
- }
- },
- methods: {
- sortBy: function (key) {
- this.sortKey = key
- this.sortOrders[key] = this.sortOrders[key] * -1
- }
- }
- })
- // bootstrap the demo
- var demo = new Vue({
- el: '#demo',
- data: {
- searchQuery: '',
- gridColumns: ['name', 'power'],
- gridData: [
- { name: 'Chuck Norris', power: Infinity },
- { name: 'Bruce Lee', power: 9000 },
- { name: 'Jackie Chan', power: 7000 },
- { name: 'Jet Li', power: 8000 }
- ]
- }
- })
|