美文网首页
vue(一)- 过滤器

vue(一)- 过滤器

作者: 编程小橙子 | 来源:发表于2018-11-20 06:02 被阅读0次

全局过滤器和局部过滤器的使用以及区别 2018-11-20

1.定义过滤器的条件:过滤器名称和处理函数
2.全局过滤器可以让所有vm实例共享;局部过滤器只针对指定的vm实例
3.当全局过滤器和局部过滤器的参数名字相同的时候,采用就近原则,优先调用局部过滤器
4.全局过滤器使用Vue.filter()   局部过滤器使用filters:{}
5.过滤器可以传递参数
6.过滤器可以传递多个参数
7.过滤器可以被多次调用

<!DOCTYPE html>
  <html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <script src="js/vue-2.4.0.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <body>
        <div id="big_box">
            <h1>{{dt | dateFormat()}}</h1>
        </div>
        <div id="box">
            <h1>{{dt | dateFormat()}}</h1>
        </div>
    </body>
    <script type="text/javascript">
        //定义了一个全局过滤器
        Vue.filter('dateFormat', function(dateStr, pattern) {
            var dt = new Date(dateStr)
            var y = dt.getFullYear()
            var m = dt.getMonth() + 1
            var d = dt.getDate()
            var hh = dt.getHours()
            var mm = dt.getMinutes()
            var ss = dt.getSeconds()
            if(pattern && pattern.toLowerCase() == 'yyyy-mm-dd') {
                return `${y}-${m}-${d}`
            } else {
                return `${y}-${m}-${d} ${hh}:${mm}:${ss}---全局`
            }
        })
        //实例化一个vue
        var vms = new Vue({
            el: '#big_box',
            data: {
                dt: new Date()
            }
        })
        //实例化一个vue
        var vm = new Vue({
            el: '#box',
            data: {
                dt: new Date()
            },
            filters: { //定义一个局部过滤器
                dateFormat: function(dateStr, pattern) {
                    var dt = new Date(dateStr)
                    var y = dt.getFullYear()
                    var m = dt.getMonth() + 1
                    var d = dt.getDate()
                    var hh = dt.getHours()
                    var mm = dt.getMinutes()
                    var ss = dt.getSeconds()
                    if(pattern && pattern.toLowerCase() == 'yyyy-mm-dd') {
                        return `${y}-${m}-${d}`
                    } else {
                        return `${y}-${m}-${d} ${hh}:${mm}:${ss}---局部`
                    }
                }
            }
        })
    </script>
</html>

相关文章

  • tool.js

    vue时间格式过滤器(今天,昨天,周几,年月日) vue金额过滤器 手机横屏签名功能(vue)

  • 6.Vue过滤器

    Vue过滤器: vue过滤器使用管道 | 进行调用,如:{{name | myFilter}},如果需要传入参数...

  • Vue-04

    过滤器:对显示在页面上的数据进行筛选 全局过滤器 和Vue同级 Vue.filter(“过滤器名称”,func...

  • vue自定义过滤器

    Vue的自定义过滤器有两种:全局过滤器和内部过滤器全局过滤器定义在vue实例化之前 内部过滤器注册在实例内部,仅在...

  • 9.自定义vue全局过滤器

    1.Vue.filter('过滤器名字',过滤器函数):

  • vue 过滤器做字数限制并显示省略号

    定义过滤器 使用vue中的 过滤器filters

  • 关于angular与vue在过滤器方面的不同

    目前看来,angular与vue在过滤器方面差异较大,总的来说angular的过滤器较简单方便,vue的过滤器更像...

  • vue 过滤器filter中this为undefined

    vue过滤器filters 中this为undefined 可以使用computed解决: vue中的过滤器更偏向...

  • vue之自定义过滤器(六)

    一、过滤器介绍:1、在Vue中会通过过滤器(Filters)来渲染数据,使视图可读性更加优雅。2、Vue中的过滤器...

  • Vue过滤器和vue-resource

    过滤器 之前我们学习了Vue的 vue基本指令 进阶学习,我们需要了解Vue的过滤器:Vue.js允许你自定义过滤...

网友评论

      本文标题:vue(一)- 过滤器

      本文链接:https://www.haomeiwen.com/subject/llazfqtx.html