zoukankan      html  css  js  c++  java
  • 507 Mustache,v-once,v-html,v-text,v-pre,v-cloak

    Mustache

    如何将data中的文本数据,插入到HTML中呢?
    我们已经学习过了,可以通过Mustache语法(也就是双大括号)。
    Mustache: 胡子/胡须.
    我们可以像下面这样来使用,并且数据是响应式的


    v-once

    但是,在某些情况下,我们可能不希望界面随意的跟随改变
    这个时候,我们就可以使用一个Vue的指令
    v-once:
    该指令后面不需要跟任何表达式(比如之前的v-for后面是由跟表达式的)
    该指令表示元素和组件(组件后面才会学习)只渲染一次,不会随着数据的改变而改变。
    代码如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    
    <body>
    
        <div id="app">
            <h2>{{message}}</h2>
            <h2 v-once>{{message}}</h2>
        </div>
    
        <script src="../js/vue.js"></script>
        <script>
            const app = new Vue({
                el: '#app',
                data: {
                    message: '你好啊'
                }
            })
        </script>
    
    </body>
    
    </html>
    

    v-html

    某些情况下,我们从服务器请求到的数据本身就是一个HTML代码
    如果我们直接通过{{}}来输出,会将HTML代码也一起输出。
    但是我们可能希望的是按照HTML格式进行解析,并且显示对应的内容。
    如果我们希望解析出HTML展示
    可以使用v-html指令
    该指令后面往往会跟上一个string类型
    会将string的html解析出来并且进行渲染

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    
    <body>
    
        <div id="app">
            <h2>{{url}}</h2>
            <h2 v-html="url"></h2>
        </div>
    
        <script src="../js/vue.js"></script>
        <script>
            const app = new Vue({
                el: '#app',
                data: {
                    message: '你好啊',
                    url: '<a href="http://www.baidu.com">百度一下</a>'
                }
            })
        </script>
    
    </body>
    
    </html>
    

    v-text

    v-text作用和Mustache比较相似:都是用于将数据显示在界面中
    v-text通常情况下,接受一个string类型

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    
    <body>
    
        <div id="app">
            <h2>{{message}}, 李银河!</h2>
            <h2 v-text="message">, 李银河!</h2>
        </div>
    
        <script src="../js/vue.js"></script>
        <script>
            const app = new Vue({
                el: '#app',
                data: {
                    message: '你好啊'
                }
            })
        </script>
    
    </body>
    
    </html>
    

    v-pre

    v-pre用于跳过这个元素和它子元素的编译过程,用于显示原本的Mustache语法。
    比如下面的代码:
    第一个h2元素中的内容会被编译解析出来对应的内容
    第二个h2元素中会直接显示{{message}}

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    
    <body>
    
        <div id="app">
            <h2>{{message}}</h2>
            <h2 v-pre>{{message}}</h2>
        </div>
    
        <script src="../js/vue.js"></script>
        <script>
            const app = new Vue({
                el: '#app',
                data: {
                    message: '你好啊'
                }
            })
        </script>
    
    </body>
    
    </html>
    

    v-cloak

    在某些情况下,我们浏览器可能会直接显然出未编译的Mustache标签。
    cloak: 斗篷

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            [v-cloak] {
                display: none;
            }
        </style>
    </head>
    
    <body>
    
        <div id="app" v-cloak>
            <h2>{{message}}</h2>
        </div>
    
        <script src="../js/vue.js"></script>
        <script>
            // 在vue解析之前, div中有一个属性v-cloak
            // 在vue解析之后, div中没有一个属性v-cloak
            setTimeout(function () {
                const app = new Vue({
                    el: '#app',
                    data: {
                        message: '你好啊'
                    }
                })
            }, 1000)
        </script>
    
    </body>
    
    </html>
    
  • 相关阅读:
    第三章-5、图片左右滑动(动态面板引导页面)
    第三章-8、抽屉导航(动态面板)
    第三章-7、没做
    第三章-6、失败
    第三章-4、瀑布流(动态面板)
    第三章-3、跳转页面&返回页面
    第三章-2、设置条件进行外部连接,跳转页面
    第三章-1、界面原件属性使用(登录界面)
    6、如何将excel表格中的图片批量居中对齐
    React Native
  • 原文地址:https://www.cnblogs.com/jianjie/p/13522602.html
Copyright © 2011-2022 走看看