最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Vue实现过滤器(filter)及应用场景

    正文概述 掘金(明天也要努力)   2021-06-11   566

    这是我参与更文挑战的第 4 天,活动详情查看:更文挑战

    1. 简单介绍

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

    <!-- 在双花括号中 -->
    {{ message | filter }}
    
    <!-- 在 `v-bind` 中 -->
    <div v-bind:msg="message | filter"></div>
    

    过滤器函数总接收表达式的值作为第一个参数。 在上述例子中,filter 过滤器函数将会收到 message 的值作为第一个参数。

    1.1 过滤器可以串联

    {{ message | filterA | filterB }}
    

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

    1.2 过滤器是 JavaScript 函数可以接收参数

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

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

    2. vue-cli中定义全局过滤器

    语法:Vue.filter( filterName,( ) => { return // 数据处理结果 } ) eg:

    <div id="app">
      <h3>{{userName | addName}}</h3>
    </div>
    <script>
    // 参数一:是过滤器的名字,也就是管道符后边的处理函数;
    // 参数二:处理函数,处理函数的参数同上	
    Vue.filter("addName",(value)=>{											            
        return "my name is" + value
    })
    let vm = new Vue({
        el:"#app",
      	data:{
         userName:"小明" 
        }
    })
    </script>
    

    2.1 实际开发使用

    1. 全局过滤器经常会被在数据修饰上,通常我们把处理函数给抽离出去,统一放在一个.js文件中。
    // filter.js 文件
    
    let filterPrice = (value) => {
    	return '已收款' + value + '元'
    }
    let filterDate = (value) => {
        return value + '天'
    }
    
    export default {filterPrice,filterDate}
    
    1. 在main.js中 导入 上边 filter.js文件 ,也可以在任何组件中导入 filter.js这个文件,但对于全局过滤器来说,最好是在main.js中定义,导入的是一个对象,所以使用Object.keys()方法,得到一个由key组成的数组,遍历数据,让key作为全局过滤器的名字,后边的是key对应的处理函数,这样在任何一个组件中都可以使用全局过滤器了:
    //main.js
     
    //下边是2种导入方式,推荐第一种
    import * as filters from './utils/filter/filter'
    // import {filterPrice,filterDate} from './utils/filter/filter'
     
    console.log(filters)
     
    Object.keys(filters.default).forEach((item)=>{
      Vue.filter(item,filters.default[item])
    })
     
    new Vue({
      router,
      store,
      render: h => h(App),
    }).$mount('#app')
    
    

    Vue实现过滤器(filter)及应用场景 3. 在组件中使用 全局过滤器:

    // test.vue
    
    <template>
      <div>
        <input type="text" v-model="filterCount" >
        <div>{{filterCount | filterPrice}}</div>
        <div>{{filterCount | filterDate}}</div>
      </div>  
    </template>
    
    <script>
    export default {
      data(){
        return {
          filterCount:1500
        }
      },
    }
    </script>
    

    Vue实现过滤器(filter)及应用场景

    3. vue-cli中定义局部过滤器

    // test.vue
    
    <template>
      <div>
        <input type="text" v-model="filterCount" >
        <div class="filter">{{filterCount | changeCapitalLetter}}</div>
      </div>  
    </template>
    
    <script>
    export default {
      data(){
        return {
          filterCount:'hello'
        }
      },
      filters:{
        changeCapitalLetter(value){	// value是输入框的内容,也是要显示的内容
          if(value){
            let str = value.toString();
            // 获取英文,以空格分组把字符串转为数组,遍历每一项,第一项转为大写字母
            let newArr = str.split(" ").map(ele=>{
              return ele.charAt(0).toUpperCase() + ele.slice(1)
            });
            return newArr.join(" ")  // 数组转字符串 以空格输出。。。
          }
        }
      },
    }
    </script>
    

    Vue实现过滤器(filter)及应用场景

    4. 常见使用场景

    4.1 格式日期(时间) 场景一:后端传的时间:2019-11-19T04:32:46Z 安装moment.js

    // main.js
    
    import moment from 'moment'
    // 定义全局过滤器--时间格式化
    Vue.filter('format',function(val,arg){
      if(!val) return;
      val = val.toString()
      return moment(val).format(arg)
    })
    
    
    // test.vue
    
    <template>
       <div class="filter">{{time | format('YYYY-MM-DD HH:MM:SS')}}</div>  
    </template>
    
    <script>
    export default {
      data(){
        return {
          time:'2019-11-19T04:32:46Z'
        }
      }
    }
    </script>
    

    Vue实现过滤器(filter)及应用场景


    起源地下载网 » Vue实现过滤器(filter)及应用场景

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元