Skip to content

4. Projeto [vuejs-02]: Utilização da estrutura CSS Bootstrap

O projeto [vuejs-02] demonstra a utilização do Bootstrap num projeto [Vue.js]. Esta é a estrutura CSS que será utilizada em todos os nossos projetos. Iremos utilizar uma variação do Bootstrap chamada [BootstrapVue] [https://bootstrap-vue.js.org/].

A estrutura de diretórios do projeto será a seguinte:

Image

Nota: No documento abaixo, a pasta [vuejs] foi renomeada para [cours] [1].

4.1. Instalação da estrutura [BootstrapVue]

O [BootstrapVue] é um framework que adicionamos ao projeto utilizando a ferramenta [npm]:

Image

  • Em [1], estamos, portanto, a instalar duas frameworks: [Bootstrap] e a sua variante [BootstrapVue];
  • em [2], ambas as dependências aparecem no ficheiro [package.json];

4.2. O script [main.js]

O script principal [main.js] é o seguinte:


// imports
import Vue from 'vue'
import App from './App.vue'
 
// plugins
import BootstrapVue from 'bootstrap-vue'
Vue.use(BootstrapVue);
 
// bootstrap
import 'bootstrap/dist/css/bootstrap.css'
import 'bootstrap-vue/dist/bootstrap-vue.css'
 
// configuration
Vue.config.productionTip = false
 
// instanciation projet [App]
new Vue({
  render: h => h(App),
}).$mount('#app')
  • linha 2: importar o framework [Vue];
  • linha 3: importar a vista principal;
  • linha 6: importar o framework [BootstrapVue];
  • linha 7: este framework foi concebido como um plugin para o framework [Vue]. A linha 7 inclui este plugin no framework [Vue];
  • linhas 10–11: importar os ficheiros CSS das estruturas [Bootstrap] e [BootstrapVue];
  • As linhas 5–11 são, portanto, inteiramente dedicadas à utilização do [BootstrapVue]. O resto do código é idêntico ao que vimos no parágrafo anterior;

4.3. O componente [App.vue]


<template>
  <b-container>
    <b-card>
      <!-- Bootstrap Jumbotron -->
      <b-jumbotron>
        <!-- ligne -->
        <b-row>
          <!-- colonne de largeur 4 -->
          <b-col cols="4">
            <img src="./assets/logo.jpg" alt="Cerisier en fleurs" />
          </b-col>
          <!-- colonne de largeur 8 -->
          <b-col cols="8">
            <h1>Calculez votre impôt</h1>
          </b-col>
        </b-row>
      </b-jumbotron>
      <HelloBootstrap msg="Hello Bootstrap !" />
    </b-card>
  </b-container>
</template>
 
 
<script>
  import HelloBootstrap from "./components/HelloBootstrap.vue";
 
  export default {
    name: "app",
    components: {
      HelloBootstrap
    }
  };
</script>

Comentários

  • linhas 1–21: todas as tags <b-xx> são tags do framework [BootstrapVue];
  • linhas 2, 20: a tag <b-container> define um contentor Bootstrap. Dentro deste contentor, podemos definir linhas usando a tag <b-row> e colunas usando a tag <b-col>;
  • linhas 3, 19: a tag <b-card> define um «cartão» Bootstrap. Visualmente, este aparece como um retângulo com uma borda;
  • linhas 5, 17: a tag <b-jumbotron> permite destacar uma secção da página, neste caso uma imagem e algum texto. Iremos utilizá-la nos nossos vários projetos como um identificador visual do projeto;
  • linha 7: a tag <b-row> define uma linha;
  • linhas 9–11: a tag <b-col> define uma coluna na linha anterior. O Bootstrap atribui 12 colunas a cada linha. O atributo [cols=’4’] indica que a coluna <b-col> ocupará 4 dessas 12 colunas;
  • Linha 10: uma imagem
  • linhas 13–15: uma coluna que ocupará 8 das 12 colunas da linha. Colocamos algum texto ali;
  • linha 18: utilização de um componente chamado [HelloBootstrap] com uma propriedade denominada [msg];
  • linhas 24–33: a parte <script> do componente;
  • linhas 29–31: o componente [HelloBootstrap] utilizado na linha 18 é exportado. Para ser reconhecido, deve ser importado na linha 25;

O resultado é o seguinte:

Image

  • em [1], a tag <b-card>;
  • em [2], a tag <jumbotron>;
  • em [3], a imagem de 4 colunas;
  • em [4], o texto de 8 colunas;

4.4. O [HelloBootstrap]

[HelloBootstrap] é o seguinte componente:


<template>
  <div>
    <!-- message on green background -->
    <b-col cols="12">
      <b-alert show variant="success" align="center">
        <h4>[vuejs-02] : bootstrap</h4>
      </b-alert>
    </b-col>
    <!-- message on yellow background -->
    <b-col cols="12">
      <b-alert show variant="warning" align="center">
        <h4>{{msg}}</h4>
      </b-alert>
    </b-col>
  </div>
</template>
 
<script>
  export default {
    name: "HelloBootstrap",
    props: {
      msg: String
    }
  };
</script>

Comentários

  • linha 3: a tag <b-alert show> exibe um retângulo colorido que normalmente contém texto (linha 6). O atributo [variant] permite selecionar um tipo de alerta. Cada tipo de alerta tem uma cor de fundo diferente. A cor da variante [success] é verde. O atributo [align] permite alinhar o texto do alerta (à esquerda, à direita ou centralizado). Note que o atributo [show] é obrigatório para exibir o alerta. Sem este atributo, o alerta não é visível;
  • Valores possíveis para [variant]:
    • [primary]: azul;
    • [secondary]: cinzento;
    • [success]: verde;
    • [danger]: vermelho claro;
    • [aviso]: amarelo;
    • [informação]: turquesa;
    • [light]: sem cor de fundo;
    • [dark]: cinzento ligeiramente mais escuro do que [secondary];
  • linha 12: [msg] é um parâmetro do componente [HelloBootstrap] (linhas 21–23);

O resultado visual é o seguinte:

Image

  • [1]: tag <b-alert show variant='success'>;
  • [2]: tag <b-alert show variant='warning'>;

4.5. Executar o projeto

Para executar o projeto, modifique primeiro o ficheiro [package.json]:

Image

  • em [3], modifique o script executado pelo comando [serve] [2] no ficheiro package.json [1];
  • em [4], execute o projeto;

Nota: A seguir, utilizaremos as tags do framework BootstrapVue, que têm o formato <b-algo>. Isto não é obrigatório. Pode utilizar as tags originais do framework Bootstrap. Elas funcionam em modelos [Vue.js]. Portanto, os programadores habituados às tags do Bootstrap podem continuar a utilizá-las.