Vue 2.0 由浅入深-过滤器

过滤器

  • 用来过滤模型数据,在现实之前进行数据处理和筛选
  • 语法{{data | filter(参数) | filter2(参数)}}
  • vue2.0中移除了所有内置的过滤器
    可以使用 loadash 第三方工具库

自定义过滤器

  • vue允许自定义过滤器
  • 过滤器可以用在两个地方:双花括号插值和 v-bind 表达式
  • vue 过滤器分为全局过滤器和局部过滤器
全局过滤器

定义全局过滤器,需要使用全局API Vue.filter()
Vue.filter('ID',function(){}) 传两个参数 第一个 是 过滤器的 id(过滤器唯一标识) 第二个是一个函数,描述过滤逻辑,函数的第一个参数是 要过滤的值 以后的参数是过滤器参数,函数逻辑处理完 须return出结果

定义过滤器
Vue.filter('ID',function(msg,arg1,arg2){
   return msg+arg1+arg2
}) 

使用过滤器 在双花括号中
{{ msg | ID (arg1,arg2)}}

使用过滤器  在  v-bind中
<div v-bind:id="msg | ID (arg1,arg2) "></div>

例如定义一个可以自定义保留几位小数的过滤器

Vue.filter('toFixed',function(msg,n){
    return msg.toFixed(n) //msg就是要过滤的值   n 就是过滤器的参数这里是保留 n 位小数
})

new Vue({
  el:"#app",
  data:{
    num:1.123456
  }
})
<div id='app'>
  <!--num就是过滤器中的 msg  2就是 过滤器传的参数 n-->
  <p>{{num | toFixed(2)}}</p>
</div>

查看自定义全局过滤器示例

局部过滤器

局部过滤器通过 vue实例 选项 filters 定义 作用仅限于该 vue实例

列如定义一个 文字翻转的过滤器

new Vue({
    el:"#app",
    data:{
        num:""
    },
    filters:{
        'reverse':function(data){
            return data.split('').reverse().join('')
        }
    }
})

使用过滤器

<input type="" v-model="num" name="" id="" value="" />
<p>{{num | reverse}}</p>

效果 输入1234 p标签内返回 4321

查看自定义局部过滤器示例

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 过滤器 filter 作用:文本数据格式化 两种过滤器:1 全局过滤器 2 局部过滤器 全局过滤器 说明:通过全局...
    想做一个画家阅读 2,166评论 0 0
  • 在这个教程中,我们将会通过几个例子,了解和学习VueJs的过滤器。我们参考了一些比较完善的过滤器,比如orderB...
    一缕清风1144阅读 10,296评论 0 1
  • 在这个教程中,我们将会通过几个例子,了解和学习VueJs的过滤器。我们参考了一些比较完善的过滤器,比如orderB...
    嘉宝_Appian阅读 4,890评论 1 4
  • Servlet过滤器是 Servlet 程序的一种特殊用法,主要用来完成一些通用的操作,如编码的过滤、判断用户的登...
    重山杨阅读 5,046评论 0 12
  • 过滤器用来格式化需要展示给用户的数据。AngularJS有很多实用的内置过滤器,同时也提供了方便的途径可以自己创建...
    oWSQo阅读 4,824评论 0 5

友情链接更多精彩内容