IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3前端青铜到黄金王者 - 第10个入门computed使用set和get -> 正文阅读

[JavaScript知识库]vue3前端青铜到黄金王者 - 第10个入门computed使用set和get

前篇写了computed属性,但是我们发现不能修改computed属性的值。

其实可以修改的我们再看看。

v computed是什么?

计算属性, 一个变量的值根据其他变量(一个或者多个)的变化,自动反映,算出新的结果。

我们可以使用 methods 来替代 computed,效果上两个都是一样的,但是 computed 是基于它的依赖缓存,只有相关依赖发生改变时才会重新取值

好,复习前面的。我们这里改造成get 和set方法。

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <title>vue3青铜到黄金-丸子酱-vue-0n</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="/vue3.1.5_vue.global.js"></script>
</head>
<body>
    <div id="wzApp">
<h3><a v-bind:href="url">点击访问->子酱@CSDN博客</a></h3>
<input v-model="num1" /><br/>
<input v-model="num2" /><br/>
<div>result {{result}} </div>
<br/><div><input v-model="result" /> </div>
    </div>
</body>
<script>
    const { createApp, ref, computed } = Vue
    const url = 'https://blog.csdn.net/qq_28008615'
    const num1 = ref(0)
    const num2 = ref(1)    
    const app = {
        /*const result1 = computed(
            ()=> int(num1.value) + int(num2.value)
        )*/
        setup() {
/**            const result = computed(
                () => Number(num1.value) + Number(num2.value)
            )*/
            const result = computed({
                get: ()=> Number(num1.value) + Number(num2.value),
                set:(v)=> v
            })
            result.value = 20
            return {
                url, num1, num2, result
            }
        }
    }   
    createApp(app).mount('#wzApp')
</script>
</html>

运行效果如下:

第一,我直接修改第三个绑定result computed属性的。
结果是可以被修改到的。但是上面的result div块不会被更新,因为result div内绑定的是get取值的方法。
在这里插入图片描述

第二,我直接修改第二个绑定num2 的属性的。
页面上所有的result div块会被更新,因为result div内绑定的是get取值的方法。
在这里插入图片描述

我们发现computed属性不允许修改,控制台报错了。(下一篇再讲解)
其他更多读者可以试试编写一些computed属性的代码,vue3还是增强了不少。

总结

computed 计算属性: 适合计算一个属性, 并且绑定.

computed 可以监控跟踪到不同变量值的变化来自动计算出新的结果。

通过set/get方法让computed属性更加弹性了。

今天就写到这里。

我是丸子,每天学会一个小知识。
一个前端开发
希望多多支持鼓励,感谢

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-25 12:06:48  更:2021-08-25 12:08:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 13:25:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码