From 07758bcad919a909495ce9937c1b1ae68345a09e Mon Sep 17 00:00:00 2001 From: androiddrew Date: Fri, 22 Feb 2019 15:15:17 -0500 Subject: [PATCH] basic routing --- .eslintrc.js | 4 +++- .prettierrc.js | 4 ++++ README.md | 32 ++++++++++++++++++++++++++++++++ src/App.vue | 4 ++-- src/components/EventCard.vue | 23 +++++++++++++++++++++++ src/main.js | 14 +++++++------- src/router.js | 31 ++++++++++++++++++++----------- src/views/Home.vue | 15 +-------------- 8 files changed, 92 insertions(+), 35 deletions(-) create mode 100644 .prettierrc.js create mode 100644 src/components/EventCard.vue diff --git a/.eslintrc.js b/.eslintrc.js index 3f3df4f..a2cb18e 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -3,7 +3,9 @@ module.exports = { env: { node: true }, - extends: ["plugin:vue/essential", "@vue/prettier"], + extends: ["plugin:vue/essential", + "plugin:prettier/recommended", //We added this to support prettier in VS Code + "@vue/prettier"], rules: { "no-console": process.env.NODE_ENV === "production" ? "error" : "off", "no-debugger": process.env.NODE_ENV === "production" ? "error" : "off" diff --git a/.prettierrc.js b/.prettierrc.js new file mode 100644 index 0000000..9fde8c4 --- /dev/null +++ b/.prettierrc.js @@ -0,0 +1,4 @@ +module.exports = { + singleQuote: true, // Converts double quote to single + semi: false, // Makes sure semicolons aren't added and the ones that are there will be removed +} \ No newline at end of file diff --git a/README.md b/README.md index 10b24d9..0495d17 100644 --- a/README.md +++ b/README.md @@ -1,29 +1,61 @@ # real-world-vue +## Best Practices: + +- Views are components but should be used as a page for the router to mount. Really you could rename View directory Pages if you cared. +- Reusable componets should be located in the components directory. +- Use Named Routes like `Home|` so you are changing url paths only in one place (`routes.js`). +- Use redirects in `routes.js` if your app was in production to prevent issues with external linking to you site. You can use an `alias` property instead, but this could mean in SEO there could be 2 pages with the same content. + ## Project setup + ``` npm install ``` ### Compiles and hot-reloads for development + ``` npm run serve ``` ### Compiles and minifies for production + ``` npm run build ``` +The `chunk-vendors.#####.js` file is contains all the dependencies of our app. +The `app.###.js` is the app file that contains all of the code to mount and render our app. + +The `` was included in the head of our built index file. the use of the `rel=prefetch` in this tag declaratively lets us specify resources that our pages will need very soon after loading. Therefor the browser should preload early in the lifecycle before the broswer's rendering machinery kicks in. This makes sure that the resource is available earlier and less likely to block the page's first render. See [MDN preload](https://developer.mozilla.org/en-US/docs/Web/HTML/Preloading_content) + +This prefetch occurred because in the router we have a lazy loading declaration. + +``` +{ + path: "/about", + name: "about", + // route level code-splitting + // this generates a separate chunk (about.[hash].js) for this route + // which is lazy-loaded when the route is visited. + component: () => + import(/* webpackChunkName: "about" */ "./views/About.vue") +} +``` + ### Run your tests + ``` npm run test ``` ### Lints and fixes files + ``` npm run lint ``` ### Customize configuration + See [Configuration Reference](https://cli.vuejs.org/config/). diff --git a/src/App.vue b/src/App.vue index 440354e..3866dd2 100644 --- a/src/App.vue +++ b/src/App.vue @@ -1,7 +1,7 @@