Vue.js
Created|Updated
Vue.js を試してみました。
- Ubuntu 18.10 x86_64
- nodejs 11.4.0
- Visual Studio Code 1.30.0
- Vue 2 Snippets
- Vue VS Code Extension Pack
- Google Chrome 71.0.3578.80
vue cli のインストール
$ sudo npm install -g @vue/cli
|
サンプルVue.js アプリケーションの作成
ブラウザ内のGUI で設定していきます。
手動設定を選択して、以下を指定してみました。
build
, lint
等を画面から実行できます。
サンプルVue.js アプリケーションの実行
serve
画面で、アプリを開く
を選択すると、作成したサンプルアプリが新しいタブに表示されます。
F12
キー押下して、デベロッパーツールからVue
を選択すると、Vue.js devtools でデバッグできます。
コードの編集
生成されたもの
./src/main.tsimport Vue from 'vue'; import App from './App.vue';
Vue.config.productionTip = false;
new Vue({ render: (h) => h(App), }).$mount('#app');
|
./src/App.vue<template> <div id="app"> <img alt="Vue logo" src="./assets/logo.png"> <HelloWorld msg="Welcome to Your Vue.js + TypeScript App"/> </div> </template>
<script lang="ts"> import { Component, Vue } from 'vue-property-decorator'; import HelloWorld from './components/HelloWorld.vue';
@Component({ components: { HelloWorld, }, }) export default class App extends Vue {} </script>
<style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
|
./src/components/HelloWorld.vue<template> <div class="hello"> <h1>{{ msg }}</h1> <p> For a guide and recipes on how to configure / customize this project,<br> check out the <a href="https://cli.vuejs.org" target="_blank" rel="noopener">vue-cli documentation</a>. </p> <h3>Installed CLI Plugins</h3> <ul> <li><a href="https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-babel" target="_blank" rel="noopener">babel</a></li> <li><a href="https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-typescript" target="_blank" rel="noopener">typescript</a></li> </ul> <h3>Essential Links</h3> <ul> <li><a href="https://vuejs.org" target="_blank" rel="noopener">Core Docs</a></li> <li><a href="https://forum.vuejs.org" target="_blank" rel="noopener">Forum</a></li> <li><a href="https://chat.vuejs.org" target="_blank" rel="noopener">Community Chat</a></li> <li><a href="https://twitter.com/vuejs" target="_blank" rel="noopener">Twitter</a></li> <li><a href="https://news.vuejs.org" target="_blank" rel="noopener">News</a></li> </ul> <h3>Ecosystem</h3> <ul> <li><a href="https://router.vuejs.org" target="_blank" rel="noopener">vue-router</a></li> <li><a href="https://vuex.vuejs.org" target="_blank" rel="noopener">vuex</a></li> <li><a href="https://github.com/vuejs/vue-devtools#vue-devtools" target="_blank" rel="noopener">vue-devtools</a></li> <li><a href="https://vue-loader.vuejs.org" target="_blank" rel="noopener">vue-loader</a></li> <li><a href="https://github.com/vuejs/awesome-vue" target="_blank" rel="noopener">awesome-vue</a></li> </ul> </div> </template>
<script lang="ts"> import { Component, Prop, Vue } from 'vue-property-decorator';
@Component export default class HelloWorld extends Vue { @Prop() private msg!: string; } </script>
<style scoped> h3 { margin: 40px 0 0; } ul { list-style-type: none; padding: 0; } li { display: inline-block; margin: 0 10px; } a { color: #42b983; } </style>
|