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

插值操作

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

Mustache(胡子/胡须)语法

可以通过Mustache(胡子/胡须)语法(也就是双大括号)。数据是响应式的。
在这里插入图片描述

v-once

在某些情况下,我们可能不希望界面随意的跟随改变
这个时候,我们就可以使用一个Vue的指令:v-once
该指令后面不需要跟任何表达式(比如之前的v-for后面是由跟表达式的)
该指令表示元素和组件(组件后面才会学习)只渲染一次,不会随着数据的改变而改变。
在这里插入图片描述
在控制台修改内容,可以看到
在这里插入图片描述
但是页面中显示内容并没有改变

v-html

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

在这里插入图片描述

v-text

v-text作用和Mustache比较相似:都是用于将数据显示在界面中
v-text通常情况下,接受一个string类型在这里插入图片描述

v-pre

用于跳过这个元素和它子元素的编译过程,用于显示原本的Mustache语法。
比如下面的代码:
第一个h2元素中的内容会被编译解析出来对应的内容
第二个h2元素中会直接显示{{message}}
在这里插入图片描述
显示效果
在这里插入图片描述

cloak

在某些情况下,我们浏览器可能会直接显然出未编译的Mustache标签。
cloak: 斗篷
在这里插入图片描述
在这里插入图片描述

绑定属性

v-bind指令

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

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

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

  • 作用:动态绑定属性
    缩写::
    预期:any (with argument) | Object (without argument)
    参数:attrOrProp (optional)
    在这里插入图片描述
  • v-bind有一个对应的语法糖,也就是简写方式
    在开发中,我们通常会使用语法糖的形式,因为这样更加简洁。
    简写方式如下:
    在这里插入图片描述
绑定class有两种方式:
  • 对象语法
    对象语法的含义是:class后面跟的是一个对象。
用法一:直接通过{}绑定一个类
<h2 :class="{'active': isActive}">Hello World</h2>
用法二:也可以通过判断,传入多个值
<h2 :class="{'active': isActive, 'line': isLine}">Hello World</h2>
用法三:和普通的类同时存在,并不冲突
注:如果isActive和isLine都为true,那么会有title/active/line三个类
<h2 class="title" :class="{'active': isActive, 'line': isLine}">Hello World</h2>
用法四:如果过于复杂,可以放在一个methods或者computed中
注:classes是一个计算属性
<h2 class="title" :class="classes">Hello World</h2>
  • 数组语法
    数组语法的含义是:class后面跟的是一个数组。
    数组语法有下面这些用法:
用法一:直接通过{}绑定一个类
<h2 :class="['active']">Hello World</h2>

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

用法三:和普通的类同时存在,并不冲突
注:会有title/active/line三个类
<h2 class="title" :class=“[‘active’, 'line']">Hello World</h2>

用法四:如果过于复杂,可以放在一个methods或者computed中
注:classes是一个计算属性
<h2 class="title" :class="classes">Hello World</h2>

计算属性

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

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

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

  • 计算属性是写在实例的computer选项的。
    计算属性也可以进行一些更加复杂的操作
    在这里插入图片描述
    JS的reduce方法:
    reduce方法使用

基础补充

块级作用域——let和var

在这里插入图片描述
es5中是没有块级作用域的,用的是var,如for和if
es6中有块级作用域,用的是let,如for和if
闭包可以解决没有块级作用域引起的问题就是因为function是由块级作用域的。
在这里插入图片描述
在这里插入图片描述
if和for中没有块级作用域,function中有块级作用域,所以使用function

const关键字

在这里插入图片描述
第三点:在这里插入图片描述

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

在这里插入图片描述

事件监听

条件判断

循环遍历

阶段案例

v-model

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值