vue中的过滤器实例代码详解


Posted in Javascript onJune 06, 2019

过滤器

1.过滤器规则

Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:

双花括号插值{{}}和  v-bind 表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:

<!-- 在双花括号中 -->
{{ name | Upper }}
<!-- 在 `v-bind` 中 -->
<div v-bind:id="martin | Upper"></div>

过滤器分为全局过滤器和本地过滤器,全局过滤器顾名思义就是所有Vue实例挂载的元素内都能使用,而本地过滤器则是指只有过滤器函数所在的Vue实例挂载的元素内可以使用

全局过滤器:

Vue.filter('Upper',function (name) {
    return name.toUpperCase();
});

本地过滤器:

var vm=new Vue({
    el: '#app',
    data: {
      name:'martin'
    },
    filters:{
      Upper:function (name) {
        return name.toUpperCase()
      }
    }
  })

2.串联过滤器

{{name | filterA | filterB }}

解释:

第一步:先把name 放到 filterA过滤器中进行过滤

第二步:将第一步过滤器的结果再放到 filterB再进行过滤,显示最终过滤结果

3.过滤器也可以接收参数,因为过滤器说到底只是一个函数

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

解释:

filterA 在这里应该定义为接收三个参数的过滤器函数。其中 name 的值作为第一个参数,字符串 arg1 作为第二个参数,表达式  arg2  的值作为第三个参数。

最后送给大家一个实例:

vue中的过滤器实例代码详解

源代码:

<!DOCTYPE html>
<html lang="en">
<head>  <meta charset="UTF-8">
  <title>Title</title>
  <script src="./bootstrap/js/jquery-1.10.1.js"></script>
  <link rel="stylesheet" href="./bootstrap/css/bootstrap.min.css">
  <script src="./bootstrap/js/bootstrap.min.js"></script>
</head>
<body>
<div id="app">
  <div class="form-inline">
    <label>id:
      <input type="text" class="form-control" placeholder="请输入你的id" v-model="id">
    </label>
    <label>name:
      <input type="text" class="form-control" placeholder="请输入你的name" v-model="name">
    </label>
    <button class="btn btn-success" @click="add">add</button>
    <label>请输入你的搜索关键字:
      <input type="text" class="form-control" placeholder="请输入你的搜索关键字" v-model="keyword">
    </label>
    <button class="btn btn-success" @click="search(keyword)">search</button>
  </div>
  <table class="table table-bordered table-hover table-striped">
    <thead>
    <tr>
      <th>id</th>
      <th>name</th>
      <th>ctime</th>
      <th>operation</th>
    </tr>
    </thead>
    <tbody>
    <tr v-for="(item,i) in search(keyword)" :key="item.id">
      <td>{{item.id}}</td>
      <td>{{item.name}}</td>
      <td>{{item.ctime|dateFormat}}</td>
      <td>
        <a href="#" class="btn btn-success" @click.prevent="">{{item.operation[0]}}</a>
        <a href="#" class="btn btn-success" @click.prevent="del(i)">{{item.operation[1]}}</a>
      </td>
    </tr>
    </tbody>
  </table>

</div>
<script src="https://cdn.jsdelivr.net/npm/vue"></script>
<script>
  Vue.filter('dateFormat',function (date) {
    var dy=date.getFullYear();
    var dm=date.getMonth()+1;
    var dd=date.getDate();
    var dh=date.getHours();
    var dm=date.getMinutes();
    var ds=date.getSeconds();
    return `${dy}-${dm}-${dd} ${dh}:${dm}:${ds}`
  });
  var vm=new Vue({
    el: '#app',
    data: {
      keyword:'',
      id:'',
      name:'',
      list:[{id:1,name:'宝马',ctime:new Date(),operation:['add','delete']},
        {id:2,name:'奔驰',ctime:new Date(),operation:['add','delete']},
        {id:3,name:'大众',ctime:new Date(),operation:['add','delete']}
      ]
    },
    methods:{
      add(){
        var curid=this.id;
        var curname=this.name;
        this.list.push({id:curid,name:curname,ctime:new Date(),operation:['add','delete']});
        this.id='';
        this.name='';
      },
      del(i){
        this.list.splice(i,1);
      },
      search(name){
        var arr=[];
        this.list.forEach((item,i)=>{
          if(item.name.indexOf(name)!=-1){
            arr.push(item);
          }
        });
        return arr
      }
    }
  })
</script>
</body>
</html>

总结

以上所述是小编给大家介绍的vue中的过滤器实例代码详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
驱动事件的addEvent.js代码
Mar 27 Javascript
使用jquery提交form表单并自定义action的方法
May 25 Javascript
使用jquery如何获取时间
Oct 13 Javascript
jquery对所有input type=text的控件赋值实现方法
Dec 02 Javascript
一句jQuery代码实现返回顶部效果(简单实用)
Dec 28 Javascript
详解JS中的立即执行函数
Feb 24 Javascript
vue.js系列中的vue-fontawesome使用
Feb 10 Javascript
基于vue-cli 打包时抽离项目相关配置文件详解
Mar 07 Javascript
Vue 实现把表单form数据 转化成json格式的数据
Oct 29 Javascript
JS数组Reduce方法功能与用法实例详解
Apr 29 Javascript
JavaScript实现刮刮乐效果
Nov 01 Javascript
什么是SOLID
Mar 24 Javascript
Vue响应式原理Observer、Dep、Watcher理解
Jun 06 #Javascript
原生js通过一行代码实现简易轮播图
Jun 05 #Javascript
解决IOS端微信H5页面软键盘弹起后页面下方留白的问题
Jun 05 #Javascript
详解vue父子组件关于模态框状态的绑定方案
Jun 05 #Javascript
JS中实现浅拷贝和深拷贝的代码详解
Jun 05 #Javascript
优雅的处理vue项目异常实战记录
Jun 05 #Javascript
原生JS使用Canvas实现拖拽式绘图功能
Jun 05 #Javascript
You might like
利用php绘制饼状图的实现代码
2013/06/07 PHP
PHP实现一维数组转二维数组的方法
2015/02/25 PHP
PHP获取ip对应地区和使用网络类型的方法
2015/03/11 PHP
php比较相似字符串的方法
2015/06/05 PHP
php中用unset销毁变量并释放内存
2020/05/10 PHP
GRID拖拽行的实例代码
2013/07/18 Javascript
获取非最后一列td值并将title设为该值的方法
2013/10/30 Javascript
Javascript中的异步编程规范Promises/A详细介绍
2014/06/06 Javascript
jQuery设置指定网页元素宽度和高度的方法
2015/03/25 Javascript
javascript中callee与caller的区别分析
2015/04/20 Javascript
简单谈谈json跨域
2016/03/13 Javascript
ionic js 模型 $ionicModal 可以遮住用户主界面的内容框
2016/06/06 Javascript
Javascript中prototype的使用详解
2016/06/18 Javascript
BootStrap 模态框实现刷新网页并关闭功能
2017/01/04 Javascript
node.js实现复制文本到剪切板的功能
2017/01/23 Javascript
BootStrap Table 后台数据绑定、特殊列处理、排序功能
2017/05/27 Javascript
详解Angular 开发环境搭建
2017/06/22 Javascript
JS中Object对象的原型概念基础
2018/01/29 Javascript
[01:18:43]2014 DOTA2华西杯精英邀请赛5 24 iG VS DK
2014/05/25 DOTA
python字典基本操作实例分析
2015/07/11 Python
Python lambda函数基本用法实例分析
2018/03/16 Python
用Python实现筛选文件脚本的方法
2018/10/27 Python
Python多线程多进程实例对比解析
2020/03/12 Python
Python如何进行时间处理
2020/08/06 Python
阿迪达斯西班牙官方网站:adidas西班牙
2016/07/21 全球购物
西班牙英格列斯百货官网:El Corte Inglés
2016/09/25 全球购物
Shopty西班牙:缝纫机在线销售
2018/01/26 全球购物
假日旅行社实习自我鉴定
2013/09/24 职场文书
实习自荐信
2013/10/13 职场文书
中学生运动会入场词
2014/02/12 职场文书
2014年双拥工作总结
2014/11/21 职场文书
支行行长岗位职责
2015/02/15 职场文书
活动主持人开场白
2015/05/28 职场文书
2015年社区反邪教工作总结
2015/10/14 职场文书
2016年乡镇七一建党节活动总结
2016/04/05 职场文书
python实战之用emoji表情生成文字
2021/05/08 Python