1. 过滤器filter

vue中的过滤器,主要用于文本的格式化,或者数组数据的过滤与排序等。其本质是一个函数,它不改变原始数据,只是对数据进行加工处理后返回过滤后的数据。过滤器可以用在两个地方:双花括号插值和v-bind表达式,使用时通过管道符 | 添加到表达式的尾部使用。语法如下:

  • 花括号
<div>{{ Id | formatId }}</div>
  • v-bind
<div v-bind:id="Id | formatId"></div>

2. 局部过滤器

如下例子:通过filters选项,定义了一个叫filterName的过滤器,它默认管道符前面的值作为第一个参数,filterName会返回一个格式化后的字符串。

<template>
  <div class="home_box">
    <p>{{ this.name | filterName }}</p>
  </div>
</template>

<script>
export default {
  name: 'Home',
  filters: {
    filterName(value) {
      return `${value}-过滤器`
    }
  },
  data() {
    return {
      name: '王五'
    }
  }
}
</script>

3. 全局过滤器

首先在src目录下新建一个filters.js文件,用来装所有的filter。然后在main.js中导入,挂载到vue实例上,即可在所有组件中使用。

  • filters.js
/**
 * @description 首字母大写
 */
export const capitalize = (value) => {
  if (!value) return ''
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
}
/**
 * @description 双倍
 */
export const double = (value) => {
  return value * 2
}
  • main.js
import Vue from 'vue'
import ElementUI from 'element-ui'
import App from './App.vue'
import * as filterEnum from '@/utils/filters.js'

Vue.use(ElementUI)

Object.keys(filterEnum).forEach(key => {
  Vue.filter(key, filterEnum[key])
})

const app = new Vue({
  render: h => h(App)
})

app.$mount('#app')

4. 传递参数

filter也是可以传递参数的,如下例子,过滤器filterFn接收了三个参数。其中 message 的值作为第一个参数,arg1 作为第二个参数,arg2 作为第三个参数。

<div>{{ message | filterFn('arg1', 'arg2') }}</div>

5. 过滤器串联

过滤器可以串联,如下例子,filterA 被定义为接收单个参数的过滤器函数,表达式 message 的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数 filterB,将 filterA 的结果传递到 filterB。

<div>{{ message | filterA | filterB }}</div>

5. 使用场景

过滤器使用场景很多。比如:

  1. 后端返回了一个状态,值为false/true或0/1,需要你转成文字是和否
  2. 数字/日期需要格式化等

如下例子,根据result的值,显示不同的文字。

<template>
  <div class="home_box">
    <h1>{{ result | checkcCloudless }}</h1>
  </div>
</template>

<script>
export default {
  name: 'Home',
  filters: {
    checkcCloudless(value) {
      return value ? '晴天' : '阴天'
    }
  },
  data() {
    return {
      result: false
    }
  }
}
</script>

6. filter和computed的区别

  • computed:
    • 主要用来逻辑运算,防止模板过重
    • 有缓存 只有依赖的其他数据项变化它才变
    • ,有get和set两个方法,get必须return
    • 只有依赖的其他数据项变化它才变
    • 在模板外面直接this.使用
  • filter:
    • 主要用做数据格式化的处理
    • 无法缓存 每次渲染都会执行
    • 定义方式的区别,filter可以通过filters和vue.filter定义
    • 在模板外面使用必须用this.$options.filters['filter名字']

PS:在本页按F12,在console中输入document.getElementsByClassName('panel-btn')[0].click();有惊喜哦~

往期文章

  • 纯前端提取图片颜色插件Color-Thief教学+实战完整指南
  • react-konva实战指南:Canvas高性能+易维护的组件化图形开发实现教程
  • React无限滚动插件react-infinite-scroll-component的配置+优化+避坑指南
  • 前端音频兼容解决:音频神器howler.js从基础到进阶完整使用指南
  • 使用React-OAuth进行Google/GitHub登录的教程和案例
  • 纯前端人脸识别利器:face-api.js手把手深入解析教学
  • 关于React父组件调用子组件方法forwardRef的详解和案例
  • React跨组件数据共享useContext详解和案例
  • Web图像编辑神器tui.image-editor从基础到进阶的实战指南
  • 开发个人微信小程序类目选择/盈利方式/成本控制与服务器接入指南
  • 前端图片裁剪Cropper.js核心功能与实战技巧详解
  • 编辑器也有邪修?盘点VS Code邪门/有趣的扩展
  • js使用IntersectionObserver实现目标元素可见度的交互
  • Web前端页面开发阿拉伯语种适配指南
  • 让网页拥有App体验?PWA 将网页变为桌面应用的保姆级教程PWA
  • 使用nvm管理node.js版本以及更换npm淘宝镜像源
  • 手把手教你搭建规范的团队vue项目,包含commitlint,eslint,prettier,husky,commitizen等等
本站提供的所有下载资源均来自互联网,仅提供学习交流使用,版权归原作者所有。如需商业使用,请联系原作者获得授权。 如您发现有涉嫌侵权的内容,请联系我们 邮箱:[email protected]