[TOC]

一、介绍

1、Vue.js 是什么

Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。
Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

官方网站:https://cn.vuejs.org

2、初始Vue.js

创建 demo.html




{{ message }}



这就是声明式渲染:Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统
这里的核心思想就是没有繁琐的DOM操作,例如jQuery中,我们需要先找到div节点,获取到DOM对象,然后进行一系列的节点操作

在vs code中创建代码片段:
文件 => 首选项 => 用户代码片段 => 新建全局代码片段/或文件夹代码片段:vue-html.code-snippets
注意:制作代码片段的时候,字符串中如果包含文件中复制过来的“Tab”键的空格,要换成“空格键”的空格

{
“vue htm”: {
“scope”: “html”,
“prefix”: “vuehtml”,
“body”: [
“<!DOCTYPE html>”,
““,
“”,
““,
“,
“,
“,
“ “,
““,
“”,
““,

“,
“”,
“,
“ “,
“,
““,
“”,
““,
],
“description”: “my vue template in html”
}
}

二、基本语法

1、基本数据渲染和指令

创建 01-基本数据渲染和指令.html
你看到的 v-bind 特性被称为指令。指令带有前缀 v-
除了使用插值表达式{{}}进行数据渲染,也可以使用 v-bind指令,它的简写的形式就是一个冒号(:)

data: {
content: ‘我是标题’,
message: ‘页面加载于 ‘ + new Date().toLocaleString()
}



{{content}}




{{content}}

2、双向数据绑定

创建 02-双向数据绑定.html
双向数据绑定和单向数据绑定:使用 v-model 进行双向数据绑定

data: {
searchMap:{
keyWord: ‘尚硅谷’
}
}





您要查询的是:{{searchMap.keyWord}}

3、事件

创建 03-事件.html
需求:点击查询按钮,按照输入框中输入的内容查找公司相关信息
在前面的例子基础上,data节点中增加 result,增加 methods节点 并定义 search方法

data: {
searchMap:{
keyWord: ‘尚硅谷’
},
//查询结果
result: {}
},
methods:{
search(){
console.log(‘search’)
//TODO
}
}
html中增加 button 和 p
使用 v-on 进行数件处理,v-on:click 表示处理鼠标点击事件,事件调用的方法定义在 vue 对象声明的 methods 节点中



您要查询的是:{{searchMap.keyWord}}


{{result.title}}


完善search方法

search(){
console.log(‘search’);
this.result = {
“title”:”尚硅谷”,
“site”:”http://www.atguigu.com
}
}
简写


4、修饰符

创建 04-修饰符.html
修饰符 (Modifiers) 是以半角句号(.)指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。
例如,.prevent 修饰符告诉 v-on 指令对于触发的事件调用 event.preventDefault():
即阻止事件原本的默认行为

data: {
user: {}
}






methods: {
onSubmit() {
if (this.user.username) {
console.log(‘提交表单’)
} else {
alert(‘请输入用户名’)
}
}
}

5、条件渲染

创建 05-条件渲染.html
v-if:条件指令

data: {
ok: false
}
注意:单个复选框绑定到布尔值

同意许可协议

if:Lorem ipsum dolor sit amet.


no


v-show:条件指令
使用v-show完成和上面相同的功能


show:Lorem ipsum dolor sit amet.


no

  • v-if 是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。
  • v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。
  • 相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。
  • 一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

6、列表渲染

创建 06-列表渲染.html
v-for:列表循环指令
例1:简单的列表渲染



  • {{ n }}




  • {{ n }} - {{ index }}


例2:遍历数据列表

data: {
userList: [
{ id: 1, username: ‘helen’, age: 18 },
{ id: 2, username: ‘peter’, age: 28 },
{ id: 3, username: ‘andy’, age: 38 }
]
}











{{index}} {{item.id}} {{item.username}} {{item.age}}