• vue中filter的使用


    结合Vue.js官方文档

    Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:

    <!-- 在双花括号中 -->
    {{ message | capitalize }}
    
    <!-- 在 `v-bind` 中 -->
    <div v-bind:id="rawId | formatId"></div>

    你可以在一个组件的选项中定义本地的过滤器:

    filters: {
      capitalize: function (value) {
        if (!value) return ''
        value = value.toString()
        return value.charAt(0).toUpperCase() + value.slice(1)
      }
    }

    或者在创建 Vue 实例之前全局定义过滤器:

    Vue.filter('capitalize', function (value) {
      if (!value) return ''
      value = value.toString()
      return value.charAt(0).toUpperCase() + value.slice(1)
    })
    
    new Vue({
      // ...
    })

    当全局过滤器和局部过滤器重名时,会采用局部过滤器。

    注意:全局注册是是filter,没有s。组件过滤器是filters,有s。写的时候没有s也是不会报错的,但过滤器是没有效果的。

    例子:

    (1)下面这个例子用到了 capitalize 过滤器:

     (2)过滤器可以串联:

    {{ message | filterA | filterB }}

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

    (3)过滤器是 JavaScript 函数,因此可以接收参数:

    {{ message | filterA('arg1', arg2) }}

    这里,filterA 被定义为接收三个参数的过滤器函数。其中 message 的值作为第一个参数,普通字符串 'arg1' 作为第二个参数,表达式 arg2 的值作为第三个参数。

     (4)过滤器接收多个参数

    {{ 'a','b' | filterB}}

    filters:{
      filterB:function(value,value2){
        return value + '' + value2
      }
    }

    a和b分别作为参数传给filterB



    个人理解与扩展

    一、什么是过滤器filter

    过滤器是对即将显示的数据做进一步的筛选处理,然后进行显示。

    注意:过滤器并没有改变原来的数据,只是在原数据的基础上产生新的数据。

    二、利用过滤器格式化时间形式

    后台返回给前端的时间的UNIX时间戳:2017-12-24T14:32:20.000+0000

    1、新建filter.js,写一个全局的fiter

    const formatDateTime = (value) => {
      const date = new Date(value)
      const year = date.getFullYear()
      let month = date.getMonth() + 1
      let day = date.getDate()
      let hours = date.getHours()
      let minutes = date.getMinutes()
      let seconds = date.getSeconds()
      if (month < 10) {
        month = '0' + month
      }
      if (day < 10) {
        day = '0' + day
      }
      if (hours < 10) {
        hours = '0' + hours
      }
      if (minutes === 0) {
        minutes = '00'
      }
      if (seconds < 10) {
        seconds = '0' + seconds
      }
      return year + '-' + month + '-' + day + ' ' + hours + ':' + minutes + ':' + seconds
    }
    export {
      formatDateTime
    }

    2、引入和注册全局过滤器

    import * as filters from './assets/javascript/filter'
    Object.keys(filters).forEach(key => {
        Vue.filter(key, filters[key])
    })

    3、在表格中展示的形式:

     <el-table-column label="最近编辑时间" width="160" align="center">
            <template slot-scope="scope">{{ scope.row.editTime | formatDateTime }}</template>
    </el-table-column>

    4、结果,时间格式转换成功

  • 相关阅读:
    25-[jQuery]-ajax
    25-[jQuery]-事件
    24-[jQuery]-属性操作,文档操作
    2016.8.16 JQuery学习记录
    移动端开发之图片上传与显示
    2016.8.16 HTML5重要标签及其属性学习
    2016.8.14 HTML5重要标签以及属性学习
    2016.8.14 HTML5重要标签及其属性学习
    HTML5 重要标签以及属性学习
    HTML5 重要标签及其属性学习
  • 原文地址:https://www.cnblogs.com/meiyanstar/p/14024282.html
Copyright © 2020-2023  润新知