javascript - vue 计算属性怎么传参
问题描述
计算属性怎么传参?
<ul> <li v-for='item in goods' : v-text='item.name'></li></ul>data: { goods: [{id: 2,type: 3,name: ’薯片’ },{id: 3,type: 5,name: ’冰红茶’}]},computed: { goodsType: function(type){switch (type) { case 3:return 'color: #ff9900'break; case 5:return 'color: #00BC0C'break;} }}
问题解答
回答1:传不了参的,你可以写成methods
回答2:首先,计算属性里的方法是传不了参的,根据你的代码我想你想要实现的是根据type的改变去返回颜色,那么你应该明白的是计算属性返回的值只跟它里面的依赖有关,当依赖改变的时候就会触发计算属性去重新计算然后改变值,所以你应该让type变成该vm的一个数据,进而成为该计算属性的依赖。简单代码如下:
data: { goods: [], type: 0 //这个type作为你后面计算属性的依赖项,通过其他方法改变它的值即可。},computed: { goodsType: function(){//这里将会依赖于此vm的type值,当type值改变,就会重新计算switch (this.type) { case 3:return 'color: #ff9900'break; case 5:return 'color: #00BC0C'break;} }}回答3:
这个需求用一个对象实例数据不就可以解决了吗?
colors: { 3: ’#ff9900’, 5: ’#00BC0C’}
绑定 style 为 {color: colors[item.type]}
回答4:https://cn.vuejs.org/v2/guide...计算-setter
计算属性默认只有 getter ,不过在需要时你也可以提供一个 setter :
// ...computed: { fullName: { // getter get: function () { return this.firstName + ’ ’ + this.lastName }, // setter set: function (newValue) { var names = newValue.split(’ ’) this.firstName = names[0] this.lastName = names[names.length - 1] } }}// ...
相关文章:
1. ionic 项目 ionic build android -release 打包时报错2. javascript - vue组件通过eventBus通信时,报错a.$on is not a function3. mysql_replication - mysql读写分离时如果单台写库也无法满足性能怎么解决4. mac里的docker如何命令行开启呢?5. html - vue项目中用到了elementUI问题6. angular.js - 如何控制ngrepeat输出的个数7. python - 如何用pandas处理分钟数据变成小时线?8. javascript - 在使用 vue.js element ui的时候 怎么样保留table翻页后check的值?9. python3.x - python3.5.2安装时make报错求助10. javascript - 求一款靠谱点的移动端图片查看器插件,老司机速进!

网公网安备