举报投诉联系我们 手机版 热门标签 VUE中文网
您的位置:VUE中文网 > vue过滤器的使用 Vue 3.0 过滤器

vue过滤器的使用 Vue 3.0 过滤器

2023-02-23 03:17 VUE3教程

vue过滤器的使用 Vue 3.0 过滤器

vue过滤器的使用

Vue过滤器是一种可以在模板中对数据进行处理的方法,它可以帮助我们将原始数据转换为我们想要的格式。它可以用于格式化日期、金钱、字符串等,也可以用于处理复杂的逻辑。

Vue过滤器的使用非常简单,只需要在模板中使用“|”符号将过滤器名称和要处理的数据分隔开即可。例如:

{{ message | capitalize }}

上面代码中,capitalize是一个过滤器,它会将message字符串中的所有字母转化为大写。

Vue也允许我们在使用过滤器时传入参数。例如:

{{ message | truncate(10) }}

上面代码中,truncate是一个过滤器,它会将message字符串截断到10个字符。

此外,Vue也允许我们在其它过滤器之后再使用一个过滤器。例如:

{{ message | truncate(10) | capitalize }}

上面代码中,truncate会将message字符串截断到10个字符,然后capitalize会将剩余的字符转化为大写。

最后要说明的是,Vue也允许我们自定义过滤器。例如:


#概览

从 Vue 3.0 开始,过滤器已删除,不再支持。

#2.x 语法

在 2.x,开发者可以使用过滤器来处理通用文本格式。

例如:

<template>
  <h1>Bank Account Balance</h1>
  <p>{{ accountBalance | currencyUSD }}</p>
</template>


<script>
  export default {
    props: {
      accountBalance: {
        type: Number,
        required: true
      }
    },
    filters: {
      currencyUSD(value) {
        return "$" + value
      }
    }
  }
</script>

虽然这看起来很方便,但它需要一个自定义语法,打破大括号内表达式是“只是 JavaScript”的假设,这不仅有学习成本,而且有实现成本。

#3.x 更新

在 3.x 中,过滤器已删除,不再支持。相反地,我们建议用方法调用或计算属性替换它们。

使用上面的例子,这里是一个如何实现它的例子。

<template>
  <h1>Bank Account Balance</h1>
  <p>{{ accountInUSD }}</p>
</template>


<script>
  export default {
    props: {
      accountBalance: {
        type: Number,
        required: true
      }
    },
    computed: {
      accountInUSD() {
        return "$" + this.accountBalance
      }
    }
  }
</script>

#迁移策略

我们建议用计算属性或方法代替过滤器,而不是使用过滤器。

#全局过滤器

如果在应用中全局注册了过滤器,那么在每个组件中用计算属性或方法调用来替换它可能就没那么方便了。

相反地,你可以通过全局属性在所有组件中使用它:

// main.js
const app = createApp(App)


app.config.globalProperties.$filters = {
  currencyUSD(value) {
    return "$" + value
  }
}

然后,你可以通过 $filters 对象修改所有的模板,像下面这样:

<template>
  <h1>Bank Account Balance</h1>
  <p>{{ $filters.currencyUSD(accountBalance) }}</p>
</template>

注意,这种方式只能用于方法中,不可以在计算属性中使用,因为后者只有在单个组件的上下文中定义时才有意义。

阅读全文
以上是VUE中文网为你收集整理的vue过滤器的使用 Vue 3.0 过滤器全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 VUE中文网 vue88.com 版权所有 联系我们