【vue】为什么要使用Vue.$set(target,key,value)

【vue】为什么要使用Vue.$set(target,key,value),第1张

vue中不能检测到数组和对象的两种变化:

1数组长度的变化 vmarrlength = 4

2,数组通过索引值修改内容 vmarr[1] = 'aa'

Vue$set(target,key,value)可以动态的给数组、对象添加修改数据,并更新视图中数据的显示。

vue在构造函数new Vue()时,就通过ObjectdefineProperty中的getter和setter 这两个方法,完成了对数据的绑定。所以直接通过vmarr[1] = 'aa'的方法,无法修改值触发vue中视图的更新,必须还得通过ObjectdefineProperty的方法去改变,而Vue$set()就封装了js底层的ObjectdefineProperty方法。

Vueset数组实现双向绑定的原理:其实Vueset()对于数组的处理其实就是调用了splice方法。splice是vue中的变异数组方法,添加了get和set后会引起视图响应。

变异数组:  >

先来看看一个“新手”可能犯的错误:

当把一个 JavaScript 对象传入 Vue 实例作为 data 选项,Vue 将遍历此对象中的各个属性,并使用 ObjectdefineProposer 把这些 Proposer 全部转化为 getter/setter 这就是为什么 obj 的属性没先声明的时候,无法让 Vue 进行跟踪修改。 "property 必须在 data 对象上存在才能让 Vue 将它转换为响应式的"。

针对这个问题,我们该如何处理?

对于已经创建的实例,Vue 不允许动态添加根级别的响应式 property。但是,可以使用以下两个方法处理:

第一个是 Vue 全局处理方法:Vueset( this object, ProposerName, Value),另一个是实例对象方法: this$set( this object, ProposerName, Value)

当对象需要添加多个属性时,可以采用 Objectassign() 方法:

Vue 不能检测以下数组的变动:

当你利用索引直接设置一个数组项时,例如:vmitems[indexOfItem] = newValue

当你修改数组的长度时,例如:vmitemslength = newLength

解决方案:

第一个是 Vue 全局处理方法:Vueset( thisarray , index, Value),另一个是实例对象方法: this$set( this array, index, Value)

在 Vue 前端表格展示 number 类型的数值时,如果数值过长,可能会出现展示不完全的情况,为了保持页面的美观和易读性,我们需要对数字进行四舍五入处理。下面是一些可能出现的问题以及解决方法:

1 数字展示异常,出现 NaN 或者 Infinity

当显示的数字过大或过小时,可能会出现 NaN 或 Infinity 的情况,这是因为 JavaScript 对浮点数的精度有限,而且对于一些超出范围的数字,计算机并不能准确表示,从而出现这种情况。建议在进行数值计算时,使用 Number 类型的数据,并避免使用浮点数。

2 数字位数过长

当数字位数过长时,可以使用 toFixed 方法对数字进行四舍五入处理,将其保留指定位数的小数。例如:

```js

const num = 123456789;

const roundedNum = numtoFixed(2); // 1234568

```

3 表格展示格式不合适

在使用表格展示数字时,可以考虑对数字进行格式化处理,例如添加千分位分隔符、保留指定位数的小数等。可以使用第三方库如 numeraljs 或 accountingjs 来方便地完成此类 *** 作。例如:

```js

import numeral from 'numeral';

const num = 12345678;

const formattedNum = numeral(num)format('0,0'); // 12,345,678

```

以上就是关于【vue】为什么要使用Vue.$set(target,key,value)全部的内容,包括:【vue】为什么要使用Vue.$set(target,key,value)、vue中当数据为空时的处理、Vue 深入响应式原理等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9806644.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存