一、Computed属性计算

四种计算处理的方式方法

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <!-- 计算属性 computed -->
<div id="v">
<!-- 变量凭借直接显示处理 -->
<h3>{{firstName}} {{lastName}}</h3> <!-- 第二种:在模板语法内运算处理 -->
<h3>{{firstName + " " + lastName}}</h3> <!-- 第三种:使用方法进行处理 -->
<h3>{{splicingStr()}}</h3> <!-- 第四种:使用方法的定义,声明在computed中,嵌入模板使作为变量使用 -->
<h3>{{splicingStr2}}</h3>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script type="text/javascript">
const vm = new Vue({
el : '#v',
data : {
firstName : 'Dai',
lastName : 'Zeal4J'
},
methods : {
splicingStr : function () {
return this.firstName + ' ' + this.lastName;
},
},
computed : {
splicingStr2 : function () {
return this.firstName + ' ' + this.lastName;
}
}
});
</script> </body>
</html>

如果计算逻辑更为复杂,使用computed选项的处理:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <!-- 为了显示总价格,虽然可以在模板语法内进行计算,但不建议 -->
<div id="v">
<h3>价格合计 : {{getBookSum}}</h3>
<h3>价格合计 : {{getBookSumByForIn}}</h3>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script type="text/javascript">
const v = new Vue({
el : '#v',
data : {
bookList : [
{ id : 1, name : 'Unix编程', price : 100 },
{ id : 2, name : '深入理解计算机原理', price : 100 },
{ id : 3, name : '现代操作系统', price : 100 },
{ id : 4, name : '代码大全', price : 100 }
]
},
computed : {
getBookSum : function () {
let sum = 0;
for (let i = 0; i < this.bookList.length; i++) {
sum += this.bookList[i].price;
}
return sum;
},
getBookSumByForIn : function () { // 使用ES6语法
let sum = 0;
for (let book of this.bookList) {
sum += book.price;
}
return sum;
}
} });
</script> </body>
</html>

setter&getter属性概述:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script type="text/javascript" src="../dependencies/vue.js"></script>
</head>
<body> <div id="v">
</div> <script type="text/javascript">
const v = new Vue({
el : '#v',
data : {
firstName : 'nico',
lastName : 'jacob'
},
computed : {
fullName : {
set : function (newVal) { // 如果要设置就需要传入形参中处理
// 因为一般不怎么作用于修改属性值,set用不上 -> 不写了
},
get : function () {
// 处理计算的逻辑都放在这个里面,所以省略开始直接对象名称衔接方法处理
return 0;
}
}
}
});
</script>
<!--
computed 和 method的区别在于?
computed具备缓存特性,多次重复性调用将会触发缓存
method则不具备,方法调用一次就重新赋值一次
如果是重复性的频率高的获取,可以使用computed更好,减少内存消耗
--> </body>
</html>

computed & methods的区别?

methods不具备缓存功能

/* 计算属性,用于处理一些属性合计或者需要计算得到的结果值 */
/* 这里虽然是一个方法,但是使用上看是作为一个属性进行操作 */
/* 要注意一个问题,data中的属性的值发生变化,那么将会重新调用computed内的函数,,并渲染 */
/* 当computed内部的函数被调用两次以上的情况,如果里面涉及的属性值没有发生改变,则使用缓存的值进行渲染 */

演示案例:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <div id="v">
<h3>{{getFullName()}}</h3>
<h3>{{getFullName()}}</h3>
<h3>{{getFullName()}}</h3>
<hr>
<h3>{{getFullNameByCompute}}</h3>
<h3>{{getFullNameByCompute}}</h3>
<h3>{{getFullNameByCompute}}</h3>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script type="text/javascript">
const v = new Vue({
el : '#v',
data : {
firstName : 'kobe',
lastName : 'bryant'
},
methods : {
getFullName() {
let fullName = this.firstName + this.lastName;
console.log('methods -> ' + fullName);
return fullName;
}
},
computed : {
getFullNameByCompute() {
let fullName = this.firstName + this.lastName;
console.log('computed -> ' + fullName);
return fullName;
}
}
});
</script> </body>
</html>

二、ES6相关

1、块级作用域,Let变量关键字和Var变量关键字

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <button>按钮01</button>
<button>按钮02</button>
<button>按钮03</button>
<button>按钮04</button>
<button>按钮05</button> <script type="text/javascript"> // 代码块内的作用域问题
{
var a = 100;
let b = 200;
console.log("in codeBlock var a -> " + a);
console.log("in codeBlock let b -> " + b);
}
console.log("out codeBlock var a -> " + a);
// console.log("out codeBlock let b -> " + b); // 出作用域 let修饰的变量将会报错无法获取 // --------------------------------------------------------------------------------------------------------- // 函数问题
var fun;
if (true) {
var txt = '打印的内容';
fun = function () {
console.log(txt);
}
} // 在调用的时候 txt变量可能被改变
txt = '更改的内容';
fun(); // --------------------------------------------------------------------------------------------------------- // for中的块级作用域问题
var buttons = document.getElementsByTagName('button');
// for (var i = 0; i < buttons.length; i++) {
// buttons[i].addEventListener('click', function () {
// console.log(('第' + i + '个按钮被点击')); // 第5个按钮被点击 无论点击哪一个按钮都是显示第五个按钮被点击
// });
// } // 使用闭包解决问题
for (var i = 0; i < buttons.length; i++) {
(function (ii) { // 这一行的i只是一个形参,和外部的ib
buttons[ii].addEventListener('click', function () {
console.log(('第' + (ii + 1) + '个按钮被点击'));
});
})(i);
}
// 为什么闭包能够解决上述的问题?因为函数具有作用域的功能 // 使用let则不会存在这个问题
for (let i = 0; i < buttons.length; i++) {
buttons[i].addEventListener('click', function () {
console.log(('第' + (i + 1) + '个按钮被点击'));
});
}
// ---------------------------------------------------------------------------------------------------------
</script> </body>
</html>

2、Const常量定义关键字

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <script type="text/javascript">
// const 常量修饰
// 声明变量时优先使用const定义,如果变量需要被改变赋值再使用let进行修饰 // 1、const声明的常量不允许二次赋值
const val = 100;
// val = 200; × // 2、const声明的常量不允许不赋值
// const val2; × 声明即必须赋值 // 3、如果 const常量指向的是一个对象,则不可以改变对象的指向,但是对象的属性可以被更改
const obj = {
name : 'objectA',
};
// obj = {}; × 不允许重新赋值一个新对象
obj.name = 'ooo'; // 属性允许重新赋值
</script> </body>
</html>

3、对象字面量和函数的增强:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!-- 对象字面量增强 -->
<script>
/* 常规JS创建对象写法 */
const obj = new Object(); /* 字面量JS创建对象写法 */
const literalObj = {}; /* ES5属性赋值写法 */
const p1 = {
key1 : 100,
key2 : 'aaa',
key3 : true
} /* ES6支持外部变量同名赋值 */
const key4 = 50;
const key5 = 'bbb';
const key6 = false; const p2 = {
key4,
key5,
key6
}
console.log(p2); /* ES5的方法声明 */
const m1 = {
set : function (val1, val2) { },
get : function () {
return 100;
}
}
/* ES6支持方法声明的增强 */
const m2 = {
set(val1, val2) { },
get() {
return 100;
}
}
</script>
</body>
</html>

4、对JS对象的比较判断处理方法:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<script type="text/javascript"> /* JS对象不能像后端编程语言一样,使用地址值进行判断是否为同一个对象 */
const getObject = function() {
return {
name : 'aaa',
age : 22,
gender : true
}
} /* 这里使用函数获取三个对象 */
const obj1 = getObject();
const obj2 = getObject();
const obj3 = getObject(); /* 如果三者都为同一个对象,则对obj1修改属性,其23都将改变,反之三者不是同一个对象 */
obj1.age = 33; /* 打印结果 */
console.log(obj1);
console.log(obj2);
console.log(obj3); /* 如果是这样返回的对象,就是返回一个地址,三者都为同一个对象 */
const finalObject = {
name : 'bbb',
age : 44,
gender : false
}
const getObject2 = function() {
return finalObject;
}
const obj4 = getObject2();
const obj5 = getObject2();
const obj6 = getObject2();
obj4.age = 88;
console.log(obj4);
console.log(obj5);
console.log(obj6);
</script>
</body>
</html>

【Vue】Re03 computed属性计算和ES6的一些补充的更多相关文章

  1. vue的computed属性

    vue的computed属性要注意的两个地方,1,必须有return,2,使用属性不用括号 <div> <input type="text" v-model=&q ...

  2. vue 的 computed 属性在什么时间执行

    vue 的 computed 属性在什么时间执行

  3. vue中computed(计算属性)和watch在实现父子组件props同步时的实际区分

    vue中computed和watch的对比是一个很有意思的话题. 看过官网教程以后,我们往往更倾向多使用computed.computed优点很多,却在某些时候不太适用. 今天我们就稍微讨论一下,当我 ...

  4. sau交流学习社区—vue总结:使用vue的computed属性实现监控变量变化,使用vue的watch属性监控变量变化从而实现其他业务

    有时候遇到这么个需求,输入框为空的时候,请求一遍接口,如果输入框不为空的时候,需要点击搜索按钮请求接口. 同步sau交流学习社区:https://www.mwcxs.top/page/464.html ...

  5. vue之computed(计算属性)

    所谓计算属性就是计算data里的数据属性. computed:实时监听的该功能. 即监听是否有修改(浏览器未打开时即开始监听了),监听的值有修改则添加 所监听的data数据属性变化了,自动实时修改. ...

  6. vue的computed属性的理解

    computed: { selectedQuestions() { let selectedQuestions = this.editedItem.questions; return this.que ...

  7. Vue中computed分析

    Vue中computed分析 在Vue中computed是计算属性,其会根据所依赖的数据动态显示新的计算结果,虽然使用{{}}模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的,在模板中放入太 ...

  8. vue中computed的作用以及用法

    在vue中computed是计算属性,主要作用是把数据存储到内存中,减少不必要的请求,还可以利用computed给子组件的data赋值. 参考地址:https://www.jianshu.com/p/ ...

  9. Vue.js学习 Item5 -- 计算属性computed与$watch

    在模板中绑定表达式是非常便利的,但是它们实际上只用于简单的操作.模板是为了描述视图的结构.在模板中放入太多的逻辑会让模板过重且难以维护.这就是为什么 Vue.js 将绑定表达式限制为一个表达式.如果需 ...

  10. vue中的computed(计算属性)和watch(监听属性)的特点,以及深度监听

    //计算属性是根据data中已有的属性,计算得到一个新的属性, <div>全名:{{fullName}}</div> 创建计算属性通过computed关键字,它是一个对象 计算 ...

随机推荐

  1. 2023 Hive 面试宝典

    先说一些废话 总结一下Hive面试宝典,方便读者快速过一遍Hive面试所需要的知识点 Hive的介绍 Hive和Hadoop的关系 Hive利用hdfs存储数据,利用MapReduce查询数据 Hiv ...

  2. sqlite3自动插入创建时间和更新时间

    最近在记录一些简单的结构化日志信息时,用到了sqlite3数据库(保存的信息比较简单,用Mysql,SQL Server,Postgres这些数据库有点小题大做). 以前开发系统时,用Mysql和Po ...

  3. Unity 3D 的NEW (堆内存)

    用容器装 在AWEKE NEW 运行时NEW 会导致分配内存时界面卡住, new class 的时候 才刷新程序帧 AWEKE 是程序启动时还没走完第一帧的开头执行 AWEKE 里面的代码 常量也在A ...

  4. 使用final shell 连接使用 ubuntu server linux

    书接上回,VM 安装ubuntu server:https://www.cnblogs.com/runliuv/p/16880599.html 1.从 https://www.hostbuf.com/ ...

  5. Postman 的 Basic Auth 如何通过 Feign 实现

    Postman 的 Basic Auth: 分析 根据以上图片分析: Postman 的 Authorization 实际为: header 中添加 Authorization: ******* ** ...

  6. 关于vue中image控件,onload事件里,event.target 为null的奇怪问题探讨

    废话不多说(主要文笔比较差),直接上代码 一个简单的demo,如下 <img :src="orginalImgSrc" style="display: none;& ...

  7. MAC下Cowardly refusing to 'sudo brew install解决方案

    副标题:<论学习英语的重要性> 在执行'sudo brew install cmake'的时候报错,错误信息如下. (一脸懵逼) 解决方案: 其实报错信息都说好了,大概意思是不能用管理员权 ...

  8. P1551 亲戚 题解。。。

    并查集 目录 并查集 (1.概念: (2.详解 Q1:如何表示不同的家族 ans1: Q2:如何将两个人归到同一个家族中 ans2: CODE: PS: (1.概念: 处理 不相交 可合并 的集合关系 ...

  9. Vue 是如何实现数据双向绑定的?

    Vue 数据双向绑定主要是指: 数据变化更新视图 视图变化更新数据. 即: 输入框内容变化时,Data 中的数据同步变化.即 View => Data 的变化. Data 中的数据变化时,文本节 ...

  10. Vue 的父组件和子组件生命周期钩子函数执行顺序?

    https://www.cnblogs.com/thinheader/p/9462125.html 参考连接 Vue 的父组件和子组件生命周期钩子函数执行顺序可以归类为以下 4 部分: 加载渲染过程 ...