首页 > 其他分享 >vue的自定义过滤器 - Filter

vue的自定义过滤器 - Filter

时间:2023-01-17 18:12:58浏览次数:79  
标签:filter vue return 自定义 value Filter filters 过滤器 capitalize

vue的自定义过滤器 - Filter
一、过滤器的介绍
二、局部过滤器
1. 定义
2. 使用
2.1 基础用法
2.2 串联用法
2.3 接收参数
三、全局过滤器
1. 定义
2. 使用
四、总结
一、过滤器的介绍
Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值 和 v-bind 表达式 。过滤器应该被添加在 JavaScript 表达式的尾部,由 “管道”符号(|) 指示。

即过滤器是用来 格式化数据 的一个函数。过滤器不会修改原始数据,它的作用是过滤数据,就是对数据进行加工处理并返回处理后的数据,比如做一些数据格式上的修改,状态转换等。

过滤器分为两种:

局部过滤器:组件内有效;
全局过滤器:所有组件共享。
二、局部过滤器
1. 定义
局部过滤器就是在一个组件的选项中定义本地的过滤器,只有该组件可以用。

2. 使用
2.1 基础用法
先通过 filters 进行注册,然后在需要过滤的变量后面,添加 管道符号( | ) 作为分隔,管道符左边是要过滤的变量,右边是过滤器名称。

<template>
  <div>
    <p :id="id | toNum">{{ message | capitalize }}</p>
  </div>
</template>

<script>
export default {
  name: 'filter',
  data () {
    return {
      message: 'hello world',
      id: '0'
    }
  },
  filters: {
    capitalize (value) {
      return value.toUpperCase().replace(/\s*/g, '')
    },
    toNum (value) {
      return Number(value)
    }
  }
}
</script>

页面效果:

 

 

2.2 串联用法

自定义过滤器支持 串联 ,也就是说可以定义多个过滤器。比如下面,相当于先用 capitalize函数 处理 message 这个数据得出结果,然后继续用 flip函数 处理前面的结果得出最终结果:

<p>{{ message | capitalize | flip}}</p>
export default {
  name: 'filter',
  data () {
    return {
      message: 'hello world'
    }
  },
  filters: {
    capitalize (value) {
      return value.toUpperCase()
    },
    flip (value) {
      return value.split('').reverse().join('')
    }
  }
}

页面效果:

 

 

2.3 接收参数

过滤器是可以 接收参数 的, 第一个参数 value 为要处理数据,剩下的参数依次为过滤变量时传入的参数:

<p>{{ message | myFilter('java','js') }}</p>
filters: {
  myFilter (value, arg1, arg2) {
    return value + ' ' + arg1 + ' ' + arg2
  }
}

注意:myFilter 被定义为接收三个参数的过滤器函数,其中 message 的值作为第一个参数 value,‘java’ 作为第二个参数 arg1,‘js’ 作为第二个参数 arg2。

页面效果:

 

 

三、全局过滤器

1. 定义

既然叫全局,那自然是在创建 Vue 实例之前全局定义过滤器,配置好后全部组件直接用就行。一般在自定义中的一个文件里专门定义。

2. 使用

  1. 在src目录下定义filters文件夹,同时在文件夹里定义一个filters.js文件:

 

 

2.在 filter.js 代码如下:

const capitalize = function (value) {
  return value.toUpperCase()
}
const flip = function (value) {
  return value.split('').reverse().join('')
}
export {capitalize, flip}

3.在main.js里引入全局过滤器:

设置 全局过滤器 方法:Vue.filter(‘过滤器名称’,对应处理函数);

import {capitalize, flip} from './filters/filters.js'

Vue.filter('capitalize', capitalize)
Vue.filter('flip', flip)

4.在任意组件中可直接使用:

<template>
  <div>
    <p>{{ message | capitalize | flip }}</p>
  </div>
</template>

<script>
export default {
  name: 'filter',
  data () {
    return {
      message: 'hello world'
    }
  }
}
</script>

 

批量全局 注册时,可将代码改写为:

filter.js:

const Filter = {
  myFilterA (value) {
    return value.toUpperCase()
  },
  myFilterB (value) {
    return value.split('').reverse().join('')
  }
}

export default Filter

main.js:

import filters from './filters/filters'

for (let filter in filters) {
  Vue.filter(filter, filters[filter])
}

剩下的使用和之前的一样。

注意:

全局注册时是 filter 没有 s , 而组件过滤器是 filters,是有 s 的,虽然写的时候没有 s 也不报错,但是过滤器是没有效果的;
当全局过滤器和局部过滤器名字重复的时候,会以就近原则进行调用,即:局部过滤器优先于全局过滤器被调用;
一个表达式可以使用多个过滤器,其执行顺序从左往右,前一个过滤器的结果作为后一个过滤器的被处理数据,所以要注意使用顺序。
四、总结
过滤器有时候同 methods、computed、watch 一样可以达到处理数据的目的,但又不能替代它们,因为它不能改变原始值 。如果一个过滤器的内部特别复杂,可以考虑把它写成一个计算属性,因为计算属性本身带有缓存,可复用性强,而过滤器一般用来做一些简单的操作。

在实际开发中,全局的过滤器要比局部过滤器使用的更广泛一些,说白了我们为什么要使用过滤器,其实就跟使用函数是一样,把一些方法封装,供其它组件使用,这样调用起来更方便快捷。

 

css 实现对话气泡框(四种箭头方向-多种方式实现)

vue中动态添加style样式的几种写法总结

 

标签:filter,vue,return,自定义,value,Filter,filters,过滤器,capitalize
From: https://www.cnblogs.com/mmzuo-798/p/17058449.html

相关文章

  • Vue+echart 展示后端获取的数据
    最近在合作做一个前后端分离项目时,为了测试我写的后端部分获取数据的效果,自己也学了一下vue的知识,在获取json信息这里也踩了很多坑。这里列举下我返回的json部分信......
  • 【VUE】Cannot read properties of undefined (reading ‘_wrapper‘)
    vue项目终端报错Cannotreadpropertiesofundefined(reading‘_wrapper‘)原因:按钮click绑定的事件在methods中没有定义,一定要查看仔细哦,有一个没定义就会报错......
  • Vue项目部署到服务器
    今天刚刚在腾讯云上买的服务器,买了个最便宜的88一年。我使用Tomcat作为web应用服务器,使用宝塔面板快速安装的Tomcat。在我们自己电脑上运行npmrunbuild命令将vue项目打......
  • Kong网关安装自定义插件
    安装自定义插件需要注意kong网关的版本要求!! 下面以安装Skywalking插件为例,要求Kong网关是2.2及以上版本,https://github.com/apache/skywalking-kong一、下载Skywalking......
  • VUE3企业级项目基础框架搭建流程(3)
    VUE-Routernpminstallvue-router@4安装完成后,在项目目录里新建一个router文件,我这里的用的是typeScript,所以建立的是router.ts,该文件是所有视图组件的映射。一般我......
  • vuejs从入门到精通——初识 vue
    初识vue  文档接下来的内容会假设你对HTML、CSS和JavaScript已经基本熟悉。如果你对前端开发完全陌生,最好不要直接从一个框架开始进行入门学习——最好是掌握了基......
  • vue3 + vue-clipboard3 复制文本到剪切板
    1.安装yarnaddvue-clipboard32.引入importuseClipboardfrom'vue-clipboard3';3.html部分<n-buttontertiarytype="primary"ref="copyBtn"@click="copyP......
  • vue-cli/webpack4.x 打包--webpack配置--样式
    css有的时候你想要向webpack的预处理器loader传递选项。可以使用 vue.config.js 中的 css.loaderOptions 选项。比如你可以这样向所有Less样式传入共享的全局......
  • Spring的OncePerRequestFilter 过滤器
    Spring的OncePerRequestFilter原文链接:https://blog.csdn.net/weixin_43944305/article/details/119923969Spring的OncePerRequestFilterOncePerRequestFilter顾名......
  • Springboot之OncePerRequestFilter 过滤器
    Springboot之OncePerRequestFilter过滤器原文链接:https://www.cnblogs.com/javalinux1/p/16389683.html类说明OncePerRequestFilter能够确保在一次请求只通过一次filte......