Book Image

The Majesty Of Vue.js

By : Alex Kyriakidis, Kostas Maniatis
Book Image

The Majesty Of Vue.js

By: Alex Kyriakidis, Kostas Maniatis

Overview of this book

<p>Vue.js is a library to build interactive web interfaces. The aim is to provide the benefits of reactive data binding and composable view components with an API that is as simple as possible.</p> <p>This book will teach you how to efficiently implement Vue.js in your projects. It starts with the fundamentals of Vue.js to building large-scale applications. You will find out what components, filters, methods, and computed properties are and how to use them to build robust applications.</p> <p>Further on, you will become familiar with ES6, single file components, module bundlers, and workflow automation. The best way to learn to code is to write it, so there’s an exercise at the end of most of the chapters for you to solve and actually test yourself on what you have learned. You can solve these in order to gain a better understanding of Vue.js.</p> <p>By the end of this book, you will be able to create fast front-end applications and increase the performance of your existing projects with Vue.js integration.</p>
Table of Contents (23 chapters)
The Majesty of Vue.js
Credits
About the Authors
www.PacktPub.com
Preface
2
Getting Started
8
Consuming an API – Preface
12
ECMAScript 6
15
Swapping Components
18
Closing Thoughts

Pagination links


By now, we have our pagination object but we always fetch the first page of stories since we are making a GET HTTP request to api/stories. We have to change the requested page based on user input (next page, previous page).

First we'll update the fetchStories method to accept an argument with the desired page. If no argument is passed, it will fetch the first page. I'll also create a new method makePagination to make the code cleaner:

new Vue({
    ...
    methods: {
        ...
        fetchStories: function (page_url) {
            var vm = this;
            page_url = page_url || '/api/stories'
            this.$http.get(page_url)
                .then(function (response) {
                    var storiesReady = response.data.data.map
                    (function (story) {
                        story.editing = false;
                        return story
                    })
                    vm...