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知识库 -> Vue.js(5):方法、计算属性和监听 -> 正文阅读

[JavaScript知识库]Vue.js(5):方法、计算属性和监听

  在Vue.js中,同样的效果可以使用不同的手段来实现,比如下面的计算:

  为了练习功能,没有做其他的判断比如除数是否为0或者输入了字母等,只是简单地通过方法、计算属性或者监听来实现两个数的相除。?

  一、使用方法来做:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>方法、计算属性和监听_方法</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="demo">
        <div>
            请输入被除数:<input type="text" v-model="add1"/>
        </div>
        <div>
             请输入除数:<input type="text" v-model="add2"/>
        </div>
        <div>两数相除结果:{{divResult()}}</div>
    </div>
    <script>
        //声明数据对象
        const vueDataObj={
            add1:1,
            add2:2,
        };
        //声明方法
        var methods={
            divResult(){
                    var result=this.add1/this.add2;
                    return result;
            }
        };
        //创建vue对象
        const vueApp=new Vue({
            el:'#demo',
            data:vueDataObj,
            methods,
            computed:{}
        });
    </script>
</body>
</html>

  二、使用计算属性来做:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>方法、计算属性和监听_计算属性</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="demo">
        <div>
            请输入被除数:<input type="text" v-model="add1"/>
        </div>
        <div>
             请输入除数:<input type="text" v-model="add2"/>
        </div>
        <div>两数相除结果:{{divResult}}</div>
    </div>

    <script>
        //声明数据对象
        const vueDataObj={
            add1:1,
            add2:2,
        };
        //声明方法
        var methods={
        };
        //声明计算属性
        var computed={
            divResult(){
                    var result=this.add1/this.add2;
                    return result;
            }
        };
        //创建vue对象
        const vueApp=new Vue({
            el:'#demo',
            data:vueDataObj,
            methods,
            computed,
        });
    </script>
</body>
</html>

  可以看到,使用方法和计算属性的差别并不大,只是函数移动了一个位置和是否加“()”的差异,可以加参数。

  三、使用监听来做,稍微有变化,有点麻烦。

  实现监听①:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>方法、计算属性和监听_监听1</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="demo">
        <div>
            请输入被除数:<input type="text" v-model="add1"/>
        </div>
        <div>
             请输入除数:<input type="text" v-model="add2"/>
        </div>
        <div>两数相除结果:{{divResult}}</div>
    </div>

    <script>
        //声明数据对象
        const vueDataObj={
            add1:1,
            add2:2,
            divResult:0.5,
        };
        //声明方法
        var methods={
        };
        //声明计算属性
        var computed={
        };
        //声明监听
        var watch={
            add1(val,oldval){
                this.divResult=this.add1/this.add2;
            },
            add2(val,oldval){
                this.divResult=this.add1/this.add2;
            }
        };
        //创建vue对象
        const vueApp=new Vue({
            el:'#demo',
            data:vueDataObj,
            methods,
            computed,
            watch,
        });
    </script>
</body>
</html>

  为了实现计算,必须监听两个数据字段,也可以在代码上做下面的变通。

  实现监听②

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>方法、计算属性和监听_监听2</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="demo">
        <div>
            请输入被除数:<input type="text" v-model="add1"/>
        </div>
        <div>
             请输入除数:<input type="text" v-model="add2"/>
        </div>
        <div>两数相除结果:{{divResult}}</div>
    </div>

    <script>
        //声明数据对象
        const vueDataObj={
            add1:1,
            add2:2,
            divResult:0.5,
        };
        //声明方法
        var methods={
            divCalc(val,oldval){
                this.divResult=this.add1/this.add2;
            }
        };
        //声明计算属性
        var computed={
        };
        //声明监听
        var watch={
            calc:'divCalc'
        };
        //创建vue对象
        const vueApp=new Vue({
            el:'#demo',
            data:vueDataObj,
            methods,
            computed,
            watch,
        });
    </script>
</body>
</html>

  如果要是数据对象,那么实现上就有特别的写法,有些参数必须加上。

  实现监听③

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>方法、计算属性和监听_监听3</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="demo">
        <div>
            请输入被除数:<input type="text" v-model="calcData.add1"/>
        </div>
        <div>
             请输入除数:<input type="text" v-model="calcData.add2"/>
        </div>
        <div>两数相除结果:{{calcData.divResult}}</div>
    </div>

    <script>
        //声明数据对象
        const vueDataObj={
            tips:'',//提示信息
            calcData:{
                add1:1,
                add2:2,
                divResult:0.5,
            },
        };
        //声明方法
        var methods={
            calc(calcObj){
                calcObj.divResult=calcObj.add1/calcObj.add2;
            }
        };
        //声明计算属性
        var computed={
        };
        //声明监听
        var watch={
            calcData:{
                handler:'calc',
                deep:true,//深度监听
                immediate:true,//有初始值
            },
        };
        //创建vue对象
        const vueApp=new Vue({
            el:'#demo',
            data:vueDataObj,
            methods,
            computed,
            watch,
        });
    </script>
</body>
</html>

  如果需要同时监听多个对象怎么办?可以如下的方式进行:

  实现监听④

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>方法、计算属性和监听_监听4</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="demo">
        <div>
            请输入被除数:<input type="text" v-model="calcData.add1"/>
        </div>
        <div>
             请输入除数:<input type="text" v-model="calcData.add2"/>
        </div>
        <div>两数相除结果:{{calcData.divResult}}</div>
    </div>

    <script>
        //声明数据对象
        const vueDataObj={
            tips:'',//提示信息
            calcData:{
                add1:1,
                add2:2,
                divResult:0.5,
            },
        };
        //声明方法
        var methods={
            calcAdd1(calcObj){
                calcObj.divResult=calcObj.add1/calcObj.add2;
            },
            calcAdd2(calcObj){
                calcObj.divResult=calcObj.add1/calcObj.add2;
            },
        };
        //声明计算属性
        var computed={
        };
        //声明监听
        var watch={
            calcData:[{
                handler:'calcAdd1',
                deep:true,//深度监听
                immediate:true,//有初始值
            },{
                handler:'calcAdd2',
                deep:true,//深度监听
                immediate:true,//有初始值
            }]
        };
        //创建vue对象
        const vueApp=new Vue({
            el:'#demo',
            data:vueDataObj,
            methods,
            computed,
            watch,
        });
    </script>
</body>
</html>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-11 17:25:59  更:2021-10-11 17:26:12 
 
开发: 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年5日历 -2024/5/18 19:18:35-

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