一、Vue是什么

参考链接:

根据官网的说法,Vue是一套用于构建用户界面的渐进式框架,即前端框架,它也是当前的三大前端框架之一。(其他两个框架分别是ReactAngular

二、Vue简单体验

1. 声明式渲染

Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统:

我们将渲染所需要数据准备在填入到新建的Vue实例中的字典中:

const app = new Vue({
el: "#app", //用于挂载要管理的元素
data: {
// data中的内容即我们渲染所需要的内容
message: "你好啊,李银河!",
name: "zengziheng"
}
})

然后在body部分使用模板语法将其取出使用:

<body>
<div id="app">
<h2>{{message}}</h2>
<h1>{{name}}</h1>
</div>
<div>{{message}}</div>
</body>

运行结果:

可以看到,只有在id="app"的元素中使用模板语法才能取出对应的值,而在这个元素之外的部分则无效。

2. vue列表展示

我们先准备一个列表数据:

const app = new Vue({
el: "#app",
data: {
message: "你好啊",
movies: ['星际穿越', '大话西游', '少年派', '盗梦空间']
}
})

然后在body中我们遍历列表将字符串取出:

<div id="app">
<ul>
<li v-for="item in movies"> {{item}} </li>
</ul>
</div>

运行结果:

这个遍历方式和java等语言中的for循环基本相同(即 for(Object o : list)

此外,如果我们除了需要得到列表中的值之外还希望得到索引(index)时,我们可以使用以下语法:

<div id="app">
<ul>
<li v-for="(item, index) in movies"> {{index}}-{{item}} </li>
</ul>
</div>

3. 处理用户输入(事件监听)

Vue中我们使用v-on指令添加一个事件监听器,通过它调用在实例中定义的方法(即回调函数):

const app = new Vue({
el: "#app",
data: {
counter: 0
},
methods: {
add: function () {
console.log("add被执行");
this.counter++;
},
sub: function () {
console.log("sub被执行");
this.counter--;
}
}
})
<div id="app">
<h2>当前计数: {{counter}}</h2>
<!-- <button v-on:click="counter--">-</button>
<button v-on:click="counter++">+</button> -->
<button v-on:click="sub">-</button>
<button v-on:click="add">+</button>
<br>
<!-- 语法糖 -->
<button @click="sub">-</button>
<button @click="add">+</button>
</div>

即这里分别给两个按钮绑定了它们对应的点击事件,当它们被点击时,对应的回调函数则会被执行,进而变量counter的值会随之改变,因为Vue框架是响应式的,故最终渲染出来的结果也会发生改变。

@则是v-on指令的语法糖,方便我们编写对应的监听指令。

三、插值操作

1. Mustache语法

var app = new Vue({
el:'#app',
data:{
message:"你好啊",
firstName:"kobe",
lastName:"bryant",
counter:100,
}
});

在实例中准备变量。

然后在body中对变量进行操作,并渲染:

<div id="app">
<h2> {{message}} </h2>
<h2> {{message}}, 李银河 </h2>
<h2> {{firstName + lastName}} </h2>
<h2> {{firstName + " " +lastName}} </h2>
<h2> {{counter*2}} </h2>
</div>

运行结果:

可以看出,在Mustache表达式中,我们可以对变量进行相应的运算,最终整个表达式可以作为一个字符串进行渲染。

2. 常用v-指令

  • v-once
  • v-html
  • v-text
  • v-pre
  • v-cloak

v-once

使当前元素中的Mustache表达式取出来的内容不再发生改变(即内容不是相应式的)

var app = new Vue({
el: '#app',
data: {
message: "你好啊",
},
methods: {
onClick() { this.message = "hello world"; }
}
});
<div id="app">
<h2>{{message}} </h2>
<h2 v-once>{{message}} </h2>
<button @click="onClick()">改变message</button>
</div>

运行时当点击按钮后:

v-html

var app = new Vue({
el:'#app',
data:{
url:'<a href="http://www.baidu.com">百度一下</a>'
}
});
<div id="app">
<h2>{{url}} </h2>
<h2 v-html="url"></h2>
</div>

即这个指令的功能是:将元素中的字符串作为html代码进行解析后再渲染,而不是直接渲染出来。

v-text

{{}}的用法基本相同,一般不使用。

v-pre

跳过这个元素和它的子元素的编译过程。即在这个元素中的所有Mustache表达式都无效。

var app = new Vue({
el:'#app',
data:{
message:"你好啊"
}
});
<div id="app">
<h2>{{message}}</h2>
<h2 v-pre>{{message}}</h2>
</div>

v-cloak

保持和元素实例的关联,直到结束编译后自动消失。

即可以使用下面的方式来避免加载时出现{{xxx}}

var app = new Vue({
el:'#app',
data:{
message:"你好啊"
}
});
[v-cloak] {
display: none;
}
<div id="app" v-cloak>
{{message}}
</div>

Vue学习笔记(一)简单使用和插值操作的更多相关文章

  1. vue学习笔记(二)——简单的介绍以及安装

    学习编程需要的是 API+不断地练习^_^ Vue官网:https://cn.vuejs.org/ 菜鸟教程:http://www.runoob.com/vue2/vue-tutorial.html ...

  2. vue 学习笔记(二)

    最近公司赶项目,一直也没时间看 vue,之前看下的都快忘得差不多了.哈哈哈,来一起回顾一下vue 学习笔记(一)后,继续向下看嘛. #表单输入绑定 基础用法 v-model 会忽略所有表单元素的 va ...

  3. vue学习笔记(八)组件校验&通信

    前言 在上一章博客的内容中vue学习笔记(七)组件我们初步的认识了组件,并学会了如何定义局部组件和全局组件,上一篇内容仅仅只是对组件一个简单的入门,并没有深入的了解组件当中的其它机制,本篇博客将会带大 ...

  4. vue学习笔记(九)vue-cli中的组件通信

    前言 在上一篇博客vue学习笔记(八)组件校验&通信中,我们学会了vue中组件的校验和父组件向子组件传递信息以及子组件通知父组件(父子组件通信),上一篇博客也提到那是对组件内容的刚刚开始,而本 ...

  5. vue学习笔记(十)路由

    前言 在上一篇博客vue学习笔记(九)vue-cli中的组件通信内容中,我们学习组件通信的相关内容和进行了一些组件通信的小练习,相信大家已经掌握了vue-cli中的组件通信,而本篇博客将会带你更上一层 ...

  6. AntDesign vue学习笔记(七)Form 读写与图片上传

    AntDesign Form使用布局相比传统Jquery有点繁琐 (一)先读写一个简单的input为例 <a-form :form="form" layout="v ...

  7. Vue学习笔记十三:Vue+Bootstrap+vue-resource从接口获取数据库数据

    目录 前言 SpringBoot提供后端接口 Entity类 JPA操作接口 配置文件 数据库表自动映射,添加数据 写提供数据的接口 跨域问题 前端修改 效果图 待续 前言 Vue学习笔记九的列表案例 ...

  8. vue学习笔记(六)表单输入绑定

    前言 在上一章vue学习笔记(四)事件处理器这一篇博客的内容中,我们已经了解vue是如何绑定事件的,而本篇博客主要讲解的是vue中表单输入的绑定,通常我们自己提交信息的时候都是通过表单将信息到服务器的 ...

  9. Vue学习笔记-Vue.js-2.X 学习(一)===>基本知识学习

    一  使用环境: windows 7 64位操作系统 二  IDE:VSCode/PyCharm 三  Vue.js官网: https://cn.vuejs.org/ 四  下载安装引用 方式1:直接 ...

  10. Vue学习笔记-rest_framework_jwt 学习

    一  使用环境 开发系统: windows 后端IDE: PyCharm 前端IDE: VSCode 数据库: msyql,navicat 编程语言: python3.7  (Windows x86- ...

随机推荐

  1. AnyCast技术

    在公司项目经历过DDoS攻击后,选用了一些比较成熟的DDoS防护厂商,在学习过程中,发现,许多DDoS厂商的防护技术都离不开 Anycast网络. 所以在这里整理一下AnyCast的相关资料. 1. ...

  2. BFS经典面试题——C++版

    文章目录 蛇梯棋 单词接龙 青蛙过河 蛇梯棋 N x N 的棋盘 board 上,按从 1 到 N*N 的数字给方格编号,编号 从左下角开始,每一行交替方向. 例如,一块 6 x 6 大小的棋盘,编号 ...

  3. 46、django工程(view)

    46.1.django view 视图函数说明: 1.http请求中产生两个核心对象: (1)http请求:HttpRequest对象. (2)http响应:HttpResponse对象. 2.vie ...

  4. [JLOI2011]飞行路线题解

    题目描述 Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n-1,一共有m种航线,每种航线连接两个城市,并且航线有一定的 ...

  5. web自动化之windows页面切换

    一.为什么切换windows页面 在页面操作过程中,存在点击某个元素之后会重新打开一个windows页面,如果不切换至新页面的话,无法在新页面中进行操作,程序会出现报错 二.如何切换 1.获取当前所有 ...

  6. 利用C语言输出一个二元一次函数

    #include<stdio.h> #include<math.h> int main(void)//其实void我认为在这可有可无 {  double a,b,c,x1,x2 ...

  7. 记一次ios下h5页面图片显示问题

    刚入职公司时做了一个移动端图片预览的组件,之前也有业务组用过,没发现什么问题,但是这次有两个很诡异的问题. 一个是老数据的图不显示,另一个是图片点击预览只显示一部分加载不全.之所以诡异是所有设备都没问 ...

  8. JS中的单例模式及单例模式原型类的实现

    单例模式 单例模式的定义: 保证一个类只有一个实例,并提供一个访问它的全局访问点 通过一个简单的例子来了解单例模式的作用: class Div { constructor() { return doc ...

  9. 消息队列——kafka

    原文:再过半小时,你就能明白kafka的工作原理了 会出现什么情况呢? 1.为了这个女朋友,我请假回去拿(老板不批). 2.小哥一直在你楼下等(小哥还有其他的快递要送). 3.周末再送(显然等不及). ...

  10. WPF教程十:如何使用Style和Behavior在WPF中规范视觉样式

    在使用WPF编写客户端代码时,我们会在VM下解耦业务逻辑,而剩下与功能无关的内容比如动画.视觉效果,布局切换等等在数量和复杂性上都超过了业务代码.而如何更好的简化这些编码,WPF设计人员使用了Styl ...