Vue 构建单页应用 1

简介和对比

  • Vue Angular React 都是基于 “单页面组件化” 思想的前端框架。

安装脚手架

  • 必须安装nodeJS(其中自带npm)
  • 安装cnpm以提升npm下载速度 => node包中国淘宝镜像 npm install -g cnpm --registry=https://registry.npm.taobao.org
  • 使用cnpm安装cli脚手架工具(命令行工具) cnpm install -g @vue/cli

创建和启动项目

  • 创建项目 vue create prjectName
  • 进入创建的项目目录,执行命令启动项目 npm run serve 访问 localhost:8080(默认) 即可看到构建好的项目
  • 打包构建项目 npm run bulid

命令都是是从 ./package.json 文件中的 "scripts" 属性中找到的。

基本目录结构

  • node_modules/ => node包目录
  • public/ => 公开目录,里面有入口文件index.html
  • src/ => 源代码目录(我们主要编写的文件)
    • assets/ => 静态资源存放目录
    • components/ => 组件目录
    • App.vue => 根组件
    • main.js => 实例化 Vue 挂载组件。
  • package.json => 项目管理文件(依赖声明、脚本声明等等...)
  • ...

只列出了重点

了解第一个组件

  • App.vue
<!-- 模板 -->
<template>
  <!-- 所有组件元素必须被一个根元素包含起来 -->
  <div id="app">
    <!-- 这里导入了Vue的Logo -->
    <img src="./assets/logo.png">
    <!-- 这里导入了组件HelloWorld -->
    <HelloWorld msg="Welcome to Your Vue.js App"/>
  </div>
</template>

<!-- js -->
<script>
// 这里引用了组件
import HelloWorld from './components/HelloWorld.vue'

export default {
  name: 'app',
  // 这里声明了组件
  components: {
    HelloWorld
  }
}
</script>

<!-- css -->
<style>
 ...
</style>
  • 可以看到,官方提供的组件是3个部分组成:<template> 静态模板, <script> js对组件的定义和声明, <style> 编辑模板中元素的css样式。
  • <script> 中,先引用了组件 /src/components/HelloWorld.vue ,然后在暴露模块时声明了属性 components 导入组件 HelloWorld.vue components: {HelloWorld}
  • 最后在 <template> 中,使用 <HelloWorld> 标签把组件展示在页面上,并且传递了一个叫 msg 的变量。
  • 再看 /src/components/HelloWorld.vue 组件
<template>
  <div class="hello">
    <!-- 在模板上显示接收的数据 -->
    <h1>{{ msg }}</h1>
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  // 声明接收的数据
  props: {
    // 接收叫 msg 的变量,类型为 String 字符串。
    msg: String
  }
}
</script>

<!-- 在style标签上添加 "scoped" 属性来声明以下css只对当前组件有效 -->
<style scoped>
 ...
</style>
  • Vue 根组件向 HelloWorld 组件传递参数后,在 HelloWorld 组件中必须使用 props: {msg: String} 来接收。
  • 限制 <style> 样式只对该组件有效,需要在添加 scoped 属性。
  • 模板插值 {{ 使用两个花括号 }}

根组件定义数据,子组件显示

  • App.vue -> <script> 中定义3种数据
<script>
import HelloWorld from './components/HelloWorld.vue'

export default {
  name: 'app',
  components: {
    HelloWorld
  },

  // 这里定义数据
  data() {
    return {
      // 字符串
      msg: "测试",

      // 对象
      person: {
        name: "张三",
        age: 18
      },

      // 数组(对象集合)
      students: [
        {id: 1, name: "张三", age:18},
        {id: 2, name: "李四", age:18},
        {id: 3, name: "王五", age:18},
      ]
    }
  }
}
</script>
  • App.vue -> <template> 中,在子组件标签 <HelloWorld> 上传递数据 <HelloWorld v-bind:msg="msg" :person="person" :students="students" />

这里 v-bind: 可以 简写为 :

  • 在 ./components/HelloWorld.vue -> <script> 中接收数据
<script>
export default {
  name: 'HelloWorld',
  props: {
    msg: String,
    person: Object,
    students: Array,
  }
}
</script>
  • HelloWorld.vue -> <template> 中遍历数据
<!-- 任何组件必须有一个根元素包起来(不能有两个最大的元素,可以把这个div理解为普通 html 中的 body 标签) -->
<div class="hello">
  <!-- 展示字符串 -->
  <h1>{{ msg }}</h1>
  
  <!-- 展示对象 -->
  <span>姓名 - {{ person.name }}</span>
  <br>
  <span>年龄 - {{ person.age }}</span>
  
  <!-- 遍历数组 -->
  <ul>
    <!-- 在遍历数组时,必须告诉 Vue 这个数组的“主键” -->
    <li v-for="student of students" :key="student.id">
      {{ student.id }} - {{ student.name }} - {{ student.age }}
    </li>
  </ul>
</div>

根组件 script 中使用 data() { return { //定义数据 } } 定义数据 -> 根组件模板中,使用:key="value"传递数据 -> 子组件 script 中使用 props 接收数据 -> 子组件使用 {{ string }} , {{ object.prop }}, v-for="data of datas" 显示数据。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容