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.ts| import 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>
 
 |