Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法

目录

    • 插值操作
        • Mustache(胡子/胡须)语法
        • v-once
        • v-html
        • v-text
        • v-pre
        • cloak
    • 绑定属性
        • v-bind指令
        • 绑定class有两种方式:
    • 计算属性
    • 基础补充
      • 块级作用域——let和var
      • const关键字
      • 对象字面量增强写法(简化):
    • 事件监听
    • 条件判断
    • 循环遍历
    • 阶段案例
    • v-model

插值操作

将data中的文本数据,插入到HTML中

Mustache(胡子/胡须)语法

可以通过Mustache(胡子/胡须)语法(也就是双大括号)。数据是响应式的。
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第1张图片

v-once

在某些情况下,我们可能不希望界面随意的跟随改变
这个时候,我们就可以使用一个Vue的指令:v-once
该指令后面不需要跟任何表达式(比如之前的v-for后面是由跟表达式的)
该指令表示元素和组件(组件后面才会学习)只渲染一次,不会随着数据的改变而改变。
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第2张图片
在控制台修改内容,可以看到
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第3张图片
但是页面中显示内容并没有改变

v-html

某些情况下,我们从服务器请求到的数据本身就是一个HTML代码
如果我们直接通过{ {}}来输出,会将HTML代码也一起输出。
但是我们可能希望的是按照HTML格式进行解析,并且显示对应的内容。
如果我们希望解析出HTML展示
可以使用v-html指令
该指令后面往往会跟上一个string类型
会将string的html解析出来并且进行渲染

Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第4张图片

v-text

v-text作用和Mustache比较相似:都是用于将数据显示在界面中
v-text通常情况下,接受一个string类型Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第5张图片

v-pre

用于跳过这个元素和它子元素的编译过程,用于显示原本的Mustache语法。
比如下面的代码:
第一个h2元素中的内容会被编译解析出来对应的内容
第二个h2元素中会直接显示{ {message}}
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第6张图片
显示效果
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第7张图片

cloak

在某些情况下,我们浏览器可能会直接显然出未编译的Mustache标签。
cloak: 斗篷
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第8张图片
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第9张图片

绑定属性

v-bind指令

某些属性我们希望动态来绑定。

  • 比如动态绑定a元素的href属性
  • 比如动态绑定img元素的src属性

这个时候,我们可以使用v-bind指令:

  • 作用:动态绑定属性
    缩写::
    预期:any (with argument) | Object (without argument)
    参数:attrOrProp (optional)
    Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第10张图片
  • v-bind有一个对应的语法糖,也就是简写方式
    在开发中,我们通常会使用语法糖的形式,因为这样更加简洁。
    简写方式如下:
    Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第11张图片

绑定class有两种方式:

  • 对象语法
    对象语法的含义是:class后面跟的是一个对象。
用法一:直接通过{
     }绑定一个类

{ 'active': isActive}">Hello World

用法二:也可以通过判断,传入多个值

{ 'active': isActive, 'line': isLine}">Hello World

用法三:和普通的类同时存在,并不冲突 注:如果isActive和isLine都为true,那么会有title/active/line三个类

{ 'active': isActive, 'line': isLine}">Hello World

用法四:如果过于复杂,可以放在一个methods或者computed中 注:classes是一个计算属性

"title" :class="classes">Hello World

  • 数组语法
    数组语法的含义是:class后面跟的是一个数组。
    数组语法有下面这些用法:
用法一:直接通过{
     }绑定一个类
<h2 :class="['active']">Hello World

用法二:也可以传入多个值
<h2 :class=“[‘active’, 'line']">Hello World

用法三:和普通的类同时存在,并不冲突
注:会有title/active/line三个类

"title" :class=“[‘active’, 'line']">Hello World

用法四:如果过于复杂,可以放在一个methods或者computed中 注:classes是一个计算属性

"title" :class="classes">Hello World

计算属性

插值语法可以显示一些data中的数据。
有时候需要对一些数据进行一些转换后在显示,或者将多个数据结合起来显示。

  • 比如我们有firstName和lastName两个变量,我们需要显示完整的名称。
  • 但是如果多个地方都需要显示完整的名称,我们就需要写多个{ {firstName}} { {lastName}}

上面的代码可以转换成计算属性。

  • 计算属性是写在实例的computer选项的。
    计算属性也可以进行一些更加复杂的操作
    Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第12张图片
    JS的reduce方法:
    reduce方法使用

基础补充

块级作用域——let和var

Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第13张图片
es5中是没有块级作用域的,用的是var,如for和if
es6中有块级作用域,用的是let,如for和if
闭包可以解决没有块级作用域引起的问题就是因为function是由块级作用域的。
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第14张图片
Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第15张图片
if和for中没有块级作用域,function中有块级作用域,所以使用function

const关键字

Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第16张图片
第三点:Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第17张图片

对象字面量增强写法(简化):

Vue基础语法——01-插值操作,绑定属性,计算属性及let和var,const关键字,对象字面量增强写法_第18张图片

事件监听

条件判断

循环遍历

阶段案例

v-model

你可能感兴趣的:(Vue)