Single-file components (SFC) consist of a template, script and style block.
When creating a new page, each template consists of at least 3 components:
<b-container><page-title><page-section>Learn more about the page titleand page section components.
<template> <b-container fluid="xl"> <page-title /> <page-section :section-title="$t('pageName.sectionTitle')"> // Page content goes here </page-section> </b-container> </template>
In the scripts section, be sure to import the PageTitle and PageSection components and declare them in the components property.
Importing BContainer in the scripts block is not required as it is already registered globally.
<script> import PageTitle from '@/components/Global/PageTitle'; import PageSection from '@/components/Global/PageSection'; export default { name: 'PageName', components: { PageTitle, PageSection } }; </script>
Add the scoped attribute to the style block to keep the styles isolated to the SFC. While the scoped attribute is optional, it is preferred and global changes should be done in global style sheets.
<style lang="scss" scoped> </style>
The final SFC will look like this.
<template> <b-container fluid="xl"> <page-title :description="$t('pageName.pageDescription')"/> <page-section :section-title="$t('pageName.sectionTitle')"> // Page content goes here </page-section> </b-container> </template> <script> import PageTitle from '@/components/Global/PageTitle'; import PageSection from '@/components/Global/PageSection'; export default { name: 'PageName', components: { PageTitle, PageSection } }; </script> <style lang="scss" scoped> .example-class { /* Styles go here */ } </style>