在Vue methods中调用filters里的过滤器实例

需求:

vue中,除了在模板中使用过滤器,有时候,methods中也需要使用filters中的过滤器,

网友hongz1125提出的解决办法:

rush:js;"> this.$options.filters[filter](...args) //这种方法很简单,也很实用

下面是我的方法,有点复杂。建议使用上面网友说的方法

rush:js;"> filters: { formatscore(score) { if (score < 20) { score = '不合格'; } else if (score >= 20 && score <= 27) { score = '合格'; } else if (score >= 28 && score <= 31) { score = '良好'; } else if (score > 31) { score = '优秀'; } return score } },methods: { formatscore(score) { if (score < 20) { score = '不合格'; } else if (score >= 20 && score <= 27) { score = '合格'; } else if (score >= 28 && score <= 31) { score = '良好'; } else if (score > 31) { score = '优秀'; } return score },getPhysicalResult() { this.$http.get('/rc_ChildTest/testResult').then((res) => { this.isdisplayIcon = this.formatscore(score参数);//使用过滤器方法,需要单独写一个一模一样的方法。通过this调用 }) },},

解决方法

1.建立一个公共的report.js文件提取封装公共js

rush:js;"> export default { formatscore(score) { if (score < 20) { score = '不合格'; } else if (score >= 20 && score <= 27) { score = '合格'; } else if (score >= 28 && score <= 31) { score = '良好'; } else if (score > 31) { score = '优秀'; } return score },}

2.导入report.js 并使用

rush:js;"> import report from 'js文件所在位置'
{ this.isdisplayIcon = report.formatscore(score参数);//这里直接使用导入的report.js中的report.formatscore方法。在methods方法中可以使用过滤器中的方法。 }) },

我是这么解决的,大家如果还有更好的方法,希望大家写在评论里,欢迎大家批评指正。

以上这篇在Vue methods中调用filters里的过滤器实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

可以通过min-width属性来设置el-table-column的最小宽度。以...
yarn dev,当文件变动后,会自动重启。 yanr start不会自动重...
ref 用于创建一个对值的响应式引用。这个值可以是原始值(如...
通过修改 getWK005 函数来实现这一点。这里的 query 参数就是...
&lt;el-form-item label=&quot;入库类型&quot; ...
API 变动 样式类名变化: 一些组件的样式类名有所变动,可能需...