Vue.js梳理(双向绑定与计算属性)

一、双向绑定

什么是:

  • 同时, 又可把表单元素的value属性的实时更改,绑定回Model数据变量上保存。------第二个方向: V => M
  • 既可把Model数据绑定到表单元素的value属性,用于显示;------第一个方向: M => V

为什么:

  • {``{}}v-bind仅是单向绑定。只能将Model数据的值,绑定到页面的表单元素上,用于显示(M => V)
  • 而页面上的更改,无法对应修改到Model数据中(V =X> M)

何时:

  • 今后,只要希望修改表单元素的值后,也能自动修改对应模型数据的值,则用v-model指令进行绑定

如何:

  • 因为只有表单元素的值才可能人为改变,所以,双向绑定几乎总是用在表单元素上。
  • 可简写为: v-model="模型变量",省略:value

自定义监视函数:

  • 什么是: 在模型数据发生变化时,自动执行的函数
  • 何时: 只有希望在模型数据变化时,立刻执行一项操作时,才需要监视函数监控模型变量
  • 如何:
  • new Vue({ el: "xxx", data: { ... }, watch:{ 模型变量名(){ this.模型变量名 ... } } })

二、绑定class和style属性

方式1:把class和style作为普通字符串进行绑定

方式2:把class和style绑定为对象

模型数据是一个对象,对象中包含每个class的名字,每个class对应一个bool值控制是否应用该class

复制代码
<span :class="unameClassObject"></span>
	unameClassObject: {
		label: true,
		'label-danger': false
		'label-success': true
	}
  • 强调: 如果class名或css属性名中间有-,则必须用""包裹起来

  • 模型数据是一个对象,对象中包含每个css属性的名值对儿


    unameStyleObject: {
    color: 'red',
    'font-size': '2em'
    }

其实, style中,还可以直接绑定一个对象语法: :style="{'css属性': 值, 'css属性':值, ... }"

三、计算属性

  • 什么是: 不实际存储属性值,而是根据其它数据属性的值,动态计算获得。

  • 为什么: 有些属性的值,不能直接获得,需要经过其它属性的值的计算后,才能获得

    • 但是! js面向对象规定: 不能在一个属性中,使用另一个属性
  • 何时: 今后,只要一个属性的值,依赖于其它数据属性的值,就要用计算属性。

    • 其实: 也可以通过定义Vue对象方法,然后绑定方法,获得返回值实现
  • 如何实现计算属性:
    定义时:

    new Vue({
    el: "xxx",
    data: { ... },
    methods:{ ... },
    watch: { ... },
    computed: {
    新属性名(){
    return 用现有数据属性执行计算
    }
    }
    })

  • 绑定时: 和普通数据属性一样!{``{计算属性}}

  • 强调: 不加()! 像一个没有set,只有get的访问器属性一样。虽然是方法,但是用法同普通属性完全一样。

相关推荐
C_心欲无痕6 分钟前
使用 XLSX.js 导出 Excel 文件
开发语言·javascript·excel
专业流量卡12 分钟前
用ai去看源码
前端·react.js
踩着两条虫14 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(六):双向代码转换之DSL到Vue代码生成
前端·vue.js·ai编程
前端老兵AI14 分钟前
React vs Vue 2026年怎么选?9年前端的真实建议
vue.js·react.js
Wect14 分钟前
React 中的双缓存 Fiber 树机制
前端·react.js·面试
天才熊猫君14 分钟前
Vue 3 中 Watch 的陷阱:为什么异步操作后创建的监听会泄漏?
前端·javascript
梵得儿SHI15 分钟前
Vue3 生态工具实战进阶:API 请求封装 + 样式解决方案全攻略(Axios/Sass/CSS Modules)
前端·css·vue3·sass·api请求·样式解决方案·组合式api管理
有梦想的咸鱼还是咸鱼吗16 分钟前
前端必会|防抖与节流从原理到实战,解决90%高频事件卡顿问题
前端
用户57573033462417 分钟前
深入 JavaScript 内存机制:从栈与堆到闭包的底层原理
javascript
阿诺木19 分钟前
Node.js 局域网设备发现:mDNS、UDP 广播和子网扫描
前端