用vscode创建vue.js项目的一个完整过程

1,新建项目
打开Visual studio code
打开一个你想要创建项目的文件夹
打开集成终端:查看 –> 集成终端 或者直接按 ctrl+`

如果没有安装vue-cli,在终端输入:

npm install -g vue-cli


全局安装vue-cli

然后新建项目

vue init webpack projectName



projectName换为你想要的名字。这里我建立的项目名为 ex1
然后一直按确认或输入y按确认,等待项目初始化,如下图

这里写图片描述

项目完成后,运行如下命令

这里写图片描述

这里写图片描述

此时,打开你最喜欢的浏览器,输入上图的地址
你应该能看到下图所显示的

这里写图片描述
2.完成项目
这时,你的项目的目录结构应该如下图所示

这里写图片描述

我们目前只关心目录src文件下的内容

接下来我们将vue.js官网的树形视图例子整合到我们的项目中。

1)在components目录下新建一个文件夹tree

2) 在新建的tree文件夹下新建一个文件tree.vue

3) 在新建的tree文件夹下新建一个文件tree.vue3) tree.vue的代码如下:(注意每修改一个文件按 ctrl + s 保存)
 

<template>
  <li>
    <div
      class="bold: isFolder"
      v-on:click="toggle"
      @dblclick="changeType">
      {{ model.name }}
      <span v-if="isFolder">[{{ open ? '-' : '+' }}]</span>
    </div>
    <ul v-show="open" v-if="isFolder">
      <tree
        class="item"
        v-for="(child, index) in model.children"
        :key="index"
        :model="child">
      </tree>
      <li class="add" @click="addChild">+</li>
    </ul>
  </li>

</template>

<style>
body {
  font-family: Menlo, Consolas, monospace;
  color: #444;
}
.item {
  cursor: pointer;
}
.bold {
  font-weight: bold;
}
ul {
  padding-left: 1em;
  line-height: 1.5em;
  list-style-type: dot;
}

</style>


<script>
import Vue from 'vue'
export default {
  name: "tree",
  props: {
    model: Object
  },
  data: function () {
    return {
      open: false
    }
  },
  computed: {
    isFolder: function () {
      return this.model.children &&
        this.model.children.length
    }
  },
  methods: {
    toggle: function() {
      if (this.isFolder) {
        this.open = !this.open;
      }
    },
    changeType: function () {
      if (!this.isFolder) {
        Vue.set(this.model, 'children', [])
        this.addChild()
        this.open = true
      }
    },
    addChild: function () {
      this.model.children.push({
        name: 'new stuff'
      })
    }
  }
}
</script>


4) app.vue的代码如下:

<template>
  <div id="app">
    <ul>
    <tree :model="data"></tree>
    </ul>
  </div>
</template>

<script>
import tree from "./components/tree/tree.vue"

export default {
  name: 'App',
  components:{
    tree
  },
  data(){
    return{
      data:data
    }
  }
}

var data = {
  name: 'My Tree',
  children: [
    { name: 'hello' },
    { name: 'wat' },
    {
      name: 'child folder',
      children: [
        {
          name: 'child folder',
          children: [
            { name: 'hello' },
            { name: 'wat' }
          ]
        },
        { name: 'hello' },
        { name: 'wat' },
        {
          name: 'child folder',
          children: [
            { name: 'hello' },
            { name: 'wat' }
          ]
        }
      ]
    }
  ]
}
</script>

<style>

</style>



如果一切正常,运行结果应该如下图

这里写图片描述

全部展开后如下图:

这里写图片描述


如果不喜欢将全部代码放在一个文件里面,可以在tree目录下新建两个文件

tree.css tree.html



然后把tree.vue中包含在template里面的代码剪切进tree.html
,把style里面的但剪切进tree.css 。
然后tree.vue的template和style部分分别变为如下

<template src="./tree.html"></template>
<style src="./tree.css"></style>


 

发布了139 篇原创文章 · 获赞 146 · 访问量 55万+

猜你喜欢

转载自blog.csdn.net/qq_40741855/article/details/104898301