vue-过滤器

文章展示了Vue中如何使用过滤器进行数据格式化,特别是在时间格式化方面的应用。通过全局和局部过滤器的定义,以及在v-bind和插值表达式中的使用,配合dayjs库展示了时间的多种格式化方法。同时,提到了过滤器可以串联使用,并且不会改变原始数据,只会生成新的处理结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vue允许定义过滤器,对于一些文本常见格式化。过滤器可以用在两个地方

-(1)v-bind 表达式

-(2){{}}插值表达式

使用:使用过滤器:{{ xxx | 过滤器名}} 或 v-bind:属性 = "xxx | 过滤器名"

注册:Vue.filter(name,callback) 或 new Vue{filters:{}}

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
  <script src="https://cdn.bootcdn.net/ajax/libs/dayjs/1.11.7/dayjs.min.js"></script>
</head>
<body>
  <!-- 准备好一个容器-->
<div id="root">
  <h2>显示格式化后的时间</h2>
  <!-- 计算属性实现 -->
  <h3>现在是:{{ fmtTime }}</h3>
  <!-- methods实现 -->
  <h3>现在是:{{ getFmtTime() }}</h3>
  <!-- 过滤器实现 -->
  <h3>现在是:{{time | timeFormater}}</h3>
  <!-- 过滤器实现(传参) -->
  <h3>现在是:{{time | timeFormater('YYYY_MM_DD') | mySlice}}</h3>
  <h3 :x="msg | mySlice">尚硅谷</h3>
</div>

<script type="text/javascript">

  //全局过滤器
  Vue.filter('mySlice',function(value){
      return value.slice(0,4)
  })

  new Vue({
      el:'#root',
      data:{
          time:Date.now(), //时间戳
          msg:'你好,尚硅谷'
      },
      // 计算属性
      computed: {
          fmtTime(){
              return dayjs(this.time).format('YYYY年MM月DD日 HH:mm:ss')
          }
      },
      // 方法
      methods: {
          getFmtTime(){
              return dayjs(this.time).format('YYYY年MM月DD日 HH:mm:ss')
          }
      },
      //局部过滤器
      filters:{
          timeFormater(value, str='YYYY年MM月DD日 HH:mm:ss'){
              // console.log('@',value)
              return dayjs(value).format(str)
          }
      }
  })
</script>
</body>
</html>

 

(1)filters和methods配置方法是一样的,在过滤器实现中<h3>现在是:{{time | timeFormater}}</h3>

会把time传递给timeFormater这个过滤器,获取的第一个参数就是出入的time值,如果在使用过滤器时传入参数,需要定义一个变量接收。

(2)<h3>现在是:{{time | timeFormater('YYYY_MM_DD') | mySlice}}</h3>

过滤器还可以串联使用,time传递给timeFormater获取得到2023年04月15日 12:00:58,再继续将结果传送给全局注册的mySlice()方法。

过滤器:并没有改变原本的数据, 是产生新的对应的数据

### Ruoyi-Vue过滤器的使用方法与实现方式 在 `Ruoyi-Vue` 项目中,过滤器主要用于数据展示前的数据转换操作。Vue.js过滤器可以用于模板表达式和 v-bind 表达式的管道语法来调用。 #### Vue.js 过滤器基础概念 Vue 提供了一种非常方便的方式来定义和使用自定义过滤器[^1]: - **局部注册**:可以在组件选项内通过 filters 属性进行局部注册。 - **全局注册**:可以通过 Vue.filter 方法进行全局注册。 #### 定义过滤器 下面是一个简单的日期格式化过滤器的例子: ```javascript // 全局过滤器 Vue.filter('formatDate', function (value) { if (!value) return ''; const date = new Date(value); return `${date.getFullYear()}-${date.getMonth()+1}-${date.getDate()} ${date.getHours()}:${date.getMinutes()}`; }); ``` 对于更复杂的逻辑,则建议创建独立的方法或引入第三方库来进行处理。 #### 组件内部使用过滤器过滤器被定义好之后,在模板中的应用就变得十分简单了。只需要在双花括号绑定后面加上竖线以及过滤器名称即可完成调用: ```html <p>发布时间: {{ article.publishTime | formatDate }}</p> ``` 如果是在 `v-bind` 指令上使用的话则需要用冒号加圆括号包裹起来的形式书写: ```html <img :src="imagePath | imageUrlFilter"> ``` 需要注意的是,从 Vue 3 开始官方已经移除了对内置过滤器的支持,推荐开发者们采用计算属性(computed properties),或是直接编写辅助函数(methods/functions) 来替代原有功能[^2]。 #### 结合 Spring Security 和 RuoYi 后端框架下的安全过滤器链设计思路 考虑到前后端分离架构下前端无法单独承担起所有的鉴权职责,因此通常会配合后端的安全模块一起工作。RuoYi 后端采用了基于 Spring Security 构建的一套完整的权限管理体系,其核心在于一系列精心编排好的 Filter 链条。这些 Filters 负责拦截请求并执行必要的认证授权流程,从而确保只有合法用户才能访问受保护资源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值