zoukankan      html  css  js  c++  java
  • VUE 过滤器以及插件

    VUE 过滤器以及插件

    过滤器

    什么是过滤器

    • 过滤器对将要显示的文本,先进行特定格式化处理,然后在进行显示。
    • 注意:过滤器并没有改变原本的数据,只是产生新的对应的数据。

    使用方式

    定义过滤器

    全局过滤器
    Vue.filter( 过滤器名称 , function(value) ){
    	// 数据处理逻辑
    })
    
    局部过滤器

    在 vue 实例中使用 filter 选项,当前实例范围可用。

    new Vue({
    	filters : {
    		过滤器名称:function ( value ) {
    			// 数据处理逻辑
    		}
    	}
    })
    

    使用过滤器

    过滤器可以用在两个地方:双花括号{{}}v-bind 表达式

    <div> {{ 数据属性名称 | 过滤器名称 }} </div>
    <div> {{ 数据属性名称 | 过滤器名称 }} </div>
    
    <div v-bind:id=" 数据属性名称 | 过滤器名称 "> </div>
    <div v-bind:id=" 数据属性名称 | 过滤器名称( 参数值 ) "> </div>
    

    演示一下

    需求

    实现过滤敏感字符,如当文本中有 tmd、sb 都进行过滤。
    过滤器传入多个参数,实现求和运算。

    实现

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>过滤器和插件</title>
    </head>
    
    <body>
        <div id="app">
            <h3>测试过滤器单个参数</h3>
            <p>{{ content | contentFilter }}</p>
            <input type="text" :value=" content | contentFilter ">
            <hr>
            <h3>测试过滤器多个参数</h3>
            <p>{{ javaScore | add(vueScore,pythonScore) }}</p>
            <input type="text" :value="javaScore | add(vueScore,pythonScore)">
        </div>
        <script src="./node_modules/vue/dist/vue.js"></script>
        <script>
            // 全局过滤器
            // Vue.filter('contentFilter', function (value) {
            //     if (!value) {
            //         return ''
            //     }
            //     return value.toString().toUpperCase().replace('TMD', '***').replace('SB', '**')
            // })
            new Vue({
                el: '#app',
                data: {
                    content: '小伙子,你TMD就是个大SB!!!',
                    javaScore: 99,
                    vueScore: 88,
                    pythonScore: 77
                },
                filters: {
                    // 定义局部过滤器
                    contentFilter(value) {
                        if (!value) {
                            return ''
                        }
                        return value.toString().toUpperCase().replace('TMD', '***').replace('SB', '**')
                    },
                    add(num1, num2, num3) {
                        // num1 其实就是 | 左边的数据
                        return num1 + num2 + num3;
                    }
                }
            })
        </script>
    </body>
    
    </html>
    

    在这里插入图片描述

    自定义插件

    插件的作用

    • 插件通常会为Vue添加全局功能,一般是添加全局方法/全局指令/过滤器等。
    • Vue插件有一个公开的方法 install ,通过 install 方法给 vue 添加全局功能。
    • 通过全局方法 Vue.use() 使用插件,他需要在你调用 new Vue() 启动应用之前完成。

    案例

    创建插件

    首先定义一个插件,创建js文件夹,在js文件夹中创建 plugins.js 文件

    (function(){
    
        // 声明 MyPlugin 插件对象
        const MyPlugin = {}
    
        MyPlugin.install = function (Vue, options) {
            // 1. 添加全局方法或 property
            Vue.myGlobalMethod = function () {
              alert("MyPlugin.myGlobalMethod 全局方法被调用了")
            }
          
            // 2. 添加全局指令
            Vue.directive('my-directive', {
              inserted (el, binding) {
                // 逻辑...
                el.innerHTML = "MyPlugin.my-directive 指令被调用了" + binding.value
              }
            })
          
            // 3. 注入组件选项
            // Vue.mixin({
            //   created: function () {
            //     // 逻辑...
            //   }
            // })
          
            // 4. 添加实例方法
            Vue.prototype.$myMethod = function (value) {
              // 逻辑...
              alert("Vue 实例方法myMethod被调用了:" + value)
            }
          }
    
          // 将插件添加到window对象
          window.MyPlugin = MyPlugin
    
    })()
    
    使用插件
    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>自定义插件</title>
    </head>
    
    <body>
    
        <div id="app">
            <span v-my-directive='content'></span>
        </div>
    
        <script src="./node_modules/vue/dist/vue.js"></script>
        <!-- 引入插件一定一定要在引入vue下面!!! -->
        <script src="js/plugins.js"></script>
    
        <script>
    
            // 引入插件,其实就是安装插件
            Vue.use(MyPlugin)
    
            var vm = new Vue({
                el: '#app',
                data: {
                    content: 'hello,wjw'
                }
            })
    
            // 调用插件中的实例,注意,是vm调用,不是Vue。
            vm.$myMethod('王佳伟')
            // 调用全局方法,注意是Vue调用,不是vm。
            Vue.myGlobalMethod()
    
        </script>
    
    </body>
    
    </html>
    

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    源码位置:https://gitee.com/wjw1014/vue_learning_course

  • 相关阅读:
    测试数据不会造?Fake Data!
    Go面试题汇总
    数据存储的 timestamp 时间正确 但是 Laravel 取出来的时间慢的 8 小时(Lumen timezone 时区设置方法(慢了8个小时))
    nginx php和html伪静态
    laravel DB操作
    深度学习_tensorflow-gpu安装:Win10-64bit+ NVIDIA GeForce MX150
    clickhouse SQL查询语句 【译自Github 英文文档】
    ELK(ElasticSearch, Logstash, Kibana)搭建实时日志分析平台
    elasticsearch max virtual memory areas vm.max_map_count [65530] is too low, increase to at le
    Pycharm 一键加引号
  • 原文地址:https://www.cnblogs.com/wjw1014/p/13386761.html
Copyright © 2011-2022 走看看