• vue-learning:19


    filters

    • 基本使用
      • 仅限在插值{{}}v-bind指令中使用
      • 管道符|分隔
      • 链式调用
      • 传入参数
    • 全局注册和局部注册
    • 纯函数性质(不能使用this

    基本使用

    我们看下之前用计算属性实现的例子,用过滤器实现

    <!-- 假设后端返回的价格单位是分,显示格式要求¥0.00元 -->
    <!-- expression -->
    <div>price:¥ {{ (price / 100).toFixed(2) }}元</div>
    <!-- computed -->
    <div>price: {{ total }}</div>
    
    
    <!-- filter -->
    <div>price: {{ price | formatPrice1 }}</div>
    <!-- filter with argument -->
    <div>price: {{ price | formatPrice2('¥') }}</div>
    <!-- filter by chain call -->
    <div>price: {{ price | formatPrice3 | symbolType('¥') }}</div>
    
    new Vue({
        el: "#app",
        data: {
            price: 100,
            memorySetterList: [],
        },
        computed: {
            total() {
                return `¥ ${(this.price / 100).toFixed(2)}元`
            }
        },
        filters: {
            formatPrice1(price) {
                return `¥ ${(this.price / 100).toFixed(2)}元`
            },
            formatPrice2(price,symbol) {
                return `${{symbol}} ${(this.price / 100).toFixed(2)}元`
            },
            formatPrice3(price) {
                return `${(this.price / 100).toFixed(2)}`
            },
            symbolType(price,symbol) {
                var list = new Map([
                    ['¥','元'],
                    ['$','美元'],
                    ['€','欧元']
                ])
                return symbol + price + list.get(symbol)
            }
        }})
    

    过滤器为我们格式化文本提供了更便捷的方法。并且price | filter比在表达式中直接写total更具可读性和扩展性。

    过滤器总是将前一个值作为第一个参数传入,自定义参数从第二个开始。使用过滤器需要注意两个事项:

    • 不能使用this来访问其它数据或方法。
      这一点是故意设计成这样的,因为过滤器必须是纯函数。也就是说不管在哪里使用,同样的输入应该保证同样的输出。如果需要使用外部数据,可以作为参数传入。
    • 只能在插值{{ }}和指令v-bind中使用
      vue 1的版本可以任何可以使用表达式的地方使用,但是vue 2中取消了这种做法,并用v-bind的使用也是在vue 2.1.0中添加的。

    过滤器注册

    之前在vue作用域讲过,分全局作用域vue,实例作用域vm=new Vue(),组件作用域。

    根据过滤器的使用范围过分别选择。

    // 全局注册,可以在任何实例内或组件内使用
    Vue.filter('filterName', function (value, arg) {
        // do something
    })
    
    // 实例注册,通过配置对象options属性传入
    var vm = new Vue({
        el: "#app",
        data: {
            price: 10000
        },
        filters: {
            filterName(value,arg) {
                // do something
            },
        }
    })
    
    // 组件内注册,只限组件内使用,其它组件无法使用
    export default {
        data() {
            return {
                price: 10000
            }
        },
        filters: {
            filterName(value,arg) {
                // do something
            },
        }
    }
    

    文件组织

    一般我们使用过滤器,也就是因为有频繁操作,所以在项目中一般过滤器都是全局注册。在项目src文件中定义一个filters文件夹,新建一个index.js

    import Vue from 'vue'
    
    var filter1 = function (value, arg) { /* do something */ }
    var filter2 = function (value, arg) { /* do something */ }
    var filter3 = function (value, arg) { /* do something */ }
    
    var filters = {
        filter1,
        filter2,
        filter3,
    }
    
    for (filter in filters) {
        Vue.filter(filter, filters[filter])
    }
    
    export default Vue
    
    // 在main.js文件导入
    import './filters/install'
    
  • 相关阅读:
    【http】HTTP请求方法 之 OPTIONS
    【javascript基础】函数前面的一元操作符
    【javascript基础】运算符优先级
    【移动互联网开发】Zepto 使用中的一些注意点 【转】
    【jQuery】IE9 jQuery 1.9.1 报 Syntax error,unrecognized expression 错误
    一月收集几个有用的谷歌Chrome插件
    【Sizzle学习】之关于【初探 jQuery 的 Sizzle 选择器】这篇文章里的小bug
    【第三方类库】underscore.js源码---each forEach 每次迭代跟{}比较的疑惑
    vue-cli脚手架npm相关文件解读(2)webpack.prod.conf.js
    vue-cli脚手架npm相关文件解读(1)webpack.base.conf.js
  • 原文地址:https://www.cnblogs.com/webxu20180730/p/10891616.html
Copyright © 2020-2023  润新知