zoukankan      html  css  js  c++  java
  • (四)Vue指令

    常用内置指令
      v:text : 更新元素的 textContent
      v-html : 更新元素的 innerHTML
      v-if : 如果为true, 当前标签才会输出到页面
      v-else: 如果为false, 当前标签才会输出到页面
      v-show : 通过控制display样式来控制显示/隐藏
      v-for : 遍历数组/对象
      v-on : 绑定事件监听, 一般简写为@
      v-bind : 强制绑定解析表达式, 可以省略v-bind
      v-model : 双向数据绑定
      ref : 为某个元素注册一个唯一标识, vue对象通过$refs属性访问这个元素对象
      v-cloak : 使用它防止闪现表达式, 与css配合: [v-cloak] { display: none }

      <!--
    1.
    注册全局指令
      Vue.directive('my-directive', function(el, binding){
        el.innerHTML = binding.value.toupperCase()
      })
    2. 注册局部指令
      directives : {
        'my-directive' : {
            bind (el, binding) {
              el.innerHTML = binding.value.toupperCase()
            }
        }
      }
    3. 使用指令
      v-my-directive='xxx'
    -->
    <!--
    需求: 自定义2个指令
      1. 功能类型于v-text, 但转换为全大写
      2. 功能类型于v-text, 但转换为全小写
    -->

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>自定义指令</title>
    </head>
    <body>
    <div id="test">
        <p v-upper-text="msg"></p>
        <p v-lower-text="msg"></p>
    </div>
    <div id="test2">
        <p v-upper-text="msg"></p>
        <p v-lower-text="msg"></p>
    </div>
    <script type="text/javascript" src="../js/vue.js"></script>
    <script type="text/javascript">
        // 注册一个全局指令
        // el: 指令所在的标签对象
        // binding: 包含指令相关数据的容器对象
        Vue.directive('upper-text', function (el, binding) {
            console.log(el, binding)
            el.textContent = binding.value.toUpperCase()
        })
        new Vue({
            el: '#test',
            data: {
                msg: "I Like You"
            },
            // 注册局部指令
            directives: {
                'lower-text'(el, binding) {
                    console.log(el, binding)
                    el.textContent = binding.value.toLowerCase()
                }
            }
    
        })
    
        new Vue({
            el: '#test2',
            data: {
                msg: "I Like You Too"
            }
        })
    </script>
    </body>
    </html>
    

      

  • 相关阅读:
    从今天起,我要在博客园装13了,听说这里装的好可以得高薪
    HTML5 选择前置摄像头,选择后置摄像头
    canvas图片base64编码后,ajax提交到后台
    238. Product of Array Except Self
    230. Kth Smallest Element in a BST
    229. Majority Element II
    228. Summary Ranges
    227. Basic Calculator II
    223. Rectangle Area
    222. Count Complete Tree Nodes
  • 原文地址:https://www.cnblogs.com/love-life-insist/p/10097623.html
Copyright © 2011-2022 走看看